linux/drivers/clk/qcom/gcc-ipq8074.c
<<
>>
Prefs
   1// SPDX-License-Identifier: GPL-2.0-only
   2/*
   3 * Copyright (c) 2017, The Linux Foundation. All rights reserved.
   4 */
   5
   6#include <linux/kernel.h>
   7#include <linux/err.h>
   8#include <linux/platform_device.h>
   9#include <linux/module.h>
  10#include <linux/of.h>
  11#include <linux/of_device.h>
  12#include <linux/clk-provider.h>
  13#include <linux/regmap.h>
  14
  15#include <dt-bindings/clock/qcom,gcc-ipq8074.h>
  16
  17#include "common.h"
  18#include "clk-regmap.h"
  19#include "clk-pll.h"
  20#include "clk-rcg.h"
  21#include "clk-branch.h"
  22#include "clk-alpha-pll.h"
  23#include "clk-regmap-divider.h"
  24#include "clk-regmap-mux.h"
  25#include "reset.h"
  26
  27enum {
  28        P_XO,
  29        P_GPLL0,
  30        P_GPLL0_DIV2,
  31        P_GPLL2,
  32        P_GPLL4,
  33        P_GPLL6,
  34        P_SLEEP_CLK,
  35        P_PCIE20_PHY0_PIPE,
  36        P_PCIE20_PHY1_PIPE,
  37        P_USB3PHY_0_PIPE,
  38        P_USB3PHY_1_PIPE,
  39        P_UBI32_PLL,
  40        P_NSS_CRYPTO_PLL,
  41        P_BIAS_PLL,
  42        P_BIAS_PLL_NSS_NOC,
  43        P_UNIPHY0_RX,
  44        P_UNIPHY0_TX,
  45        P_UNIPHY1_RX,
  46        P_UNIPHY1_TX,
  47        P_UNIPHY2_RX,
  48        P_UNIPHY2_TX,
  49};
  50
  51static const char * const gcc_xo_gpll0_gpll0_out_main_div2[] = {
  52        "xo",
  53        "gpll0",
  54        "gpll0_out_main_div2",
  55};
  56
  57static const struct parent_map gcc_xo_gpll0_gpll0_out_main_div2_map[] = {
  58        { P_XO, 0 },
  59        { P_GPLL0, 1 },
  60        { P_GPLL0_DIV2, 4 },
  61};
  62
  63static const char * const gcc_xo_gpll0[] = {
  64        "xo",
  65        "gpll0",
  66};
  67
  68static const struct parent_map gcc_xo_gpll0_map[] = {
  69        { P_XO, 0 },
  70        { P_GPLL0, 1 },
  71};
  72
  73static const char * const gcc_xo_gpll0_gpll2_gpll0_out_main_div2[] = {
  74        "xo",
  75        "gpll0",
  76        "gpll2",
  77        "gpll0_out_main_div2",
  78};
  79
  80static const struct parent_map gcc_xo_gpll0_gpll2_gpll0_out_main_div2_map[] = {
  81        { P_XO, 0 },
  82        { P_GPLL0, 1 },
  83        { P_GPLL2, 2 },
  84        { P_GPLL0_DIV2, 4 },
  85};
  86
  87static const char * const gcc_xo_gpll0_sleep_clk[] = {
  88        "xo",
  89        "gpll0",
  90        "sleep_clk",
  91};
  92
  93static const struct parent_map gcc_xo_gpll0_sleep_clk_map[] = {
  94        { P_XO, 0 },
  95        { P_GPLL0, 2 },
  96        { P_SLEEP_CLK, 6 },
  97};
  98
  99static const char * const gcc_xo_gpll6_gpll0_gpll0_out_main_div2[] = {
 100        "xo",
 101        "gpll6",
 102        "gpll0",
 103        "gpll0_out_main_div2",
 104};
 105
 106static const struct parent_map gcc_xo_gpll6_gpll0_gpll0_out_main_div2_map[] = {
 107        { P_XO, 0 },
 108        { P_GPLL6, 1 },
 109        { P_GPLL0, 3 },
 110        { P_GPLL0_DIV2, 4 },
 111};
 112
 113static const char * const gcc_xo_gpll0_out_main_div2_gpll0[] = {
 114        "xo",
 115        "gpll0_out_main_div2",
 116        "gpll0",
 117};
 118
 119static const struct parent_map gcc_xo_gpll0_out_main_div2_gpll0_map[] = {
 120        { P_XO, 0 },
 121        { P_GPLL0_DIV2, 2 },
 122        { P_GPLL0, 1 },
 123};
 124
 125static const char * const gcc_usb3phy_0_cc_pipe_clk_xo[] = {
 126        "usb3phy_0_cc_pipe_clk",
 127        "xo",
 128};
 129
 130static const struct parent_map gcc_usb3phy_0_cc_pipe_clk_xo_map[] = {
 131        { P_USB3PHY_0_PIPE, 0 },
 132        { P_XO, 2 },
 133};
 134
 135static const char * const gcc_usb3phy_1_cc_pipe_clk_xo[] = {
 136        "usb3phy_1_cc_pipe_clk",
 137        "xo",
 138};
 139
 140static const struct parent_map gcc_usb3phy_1_cc_pipe_clk_xo_map[] = {
 141        { P_USB3PHY_1_PIPE, 0 },
 142        { P_XO, 2 },
 143};
 144
 145static const char * const gcc_pcie20_phy0_pipe_clk_xo[] = {
 146        "pcie20_phy0_pipe_clk",
 147        "xo",
 148};
 149
 150static const struct parent_map gcc_pcie20_phy0_pipe_clk_xo_map[] = {
 151        { P_PCIE20_PHY0_PIPE, 0 },
 152        { P_XO, 2 },
 153};
 154
 155static const char * const gcc_pcie20_phy1_pipe_clk_xo[] = {
 156        "pcie20_phy1_pipe_clk",
 157        "xo",
 158};
 159
 160static const struct parent_map gcc_pcie20_phy1_pipe_clk_xo_map[] = {
 161        { P_PCIE20_PHY1_PIPE, 0 },
 162        { P_XO, 2 },
 163};
 164
 165static const char * const gcc_xo_gpll0_gpll6_gpll0_div2[] = {
 166        "xo",
 167        "gpll0",
 168        "gpll6",
 169        "gpll0_out_main_div2",
 170};
 171
 172static const struct parent_map gcc_xo_gpll0_gpll6_gpll0_div2_map[] = {
 173        { P_XO, 0 },
 174        { P_GPLL0, 1 },
 175        { P_GPLL6, 2 },
 176        { P_GPLL0_DIV2, 4 },
 177};
 178
 179static const char * const gcc_xo_gpll0_gpll6_gpll0_out_main_div2[] = {
 180        "xo",
 181        "gpll0",
 182        "gpll6",
 183        "gpll0_out_main_div2",
 184};
 185
 186static const struct parent_map gcc_xo_gpll0_gpll6_gpll0_out_main_div2_map[] = {
 187        { P_XO, 0 },
 188        { P_GPLL0, 1 },
 189        { P_GPLL6, 2 },
 190        { P_GPLL0_DIV2, 3 },
 191};
 192
 193static const char * const gcc_xo_bias_pll_nss_noc_clk_gpll0_gpll2[] = {
 194        "xo",
 195        "bias_pll_nss_noc_clk",
 196        "gpll0",
 197        "gpll2",
 198};
 199
 200static const struct parent_map gcc_xo_bias_pll_nss_noc_clk_gpll0_gpll2_map[] = {
 201        { P_XO, 0 },
 202        { P_BIAS_PLL_NSS_NOC, 1 },
 203        { P_GPLL0, 2 },
 204        { P_GPLL2, 3 },
 205};
 206
 207static const char * const gcc_xo_nss_crypto_pll_gpll0[] = {
 208        "xo",
 209        "nss_crypto_pll",
 210        "gpll0",
 211};
 212
 213static const struct parent_map gcc_xo_nss_crypto_pll_gpll0_map[] = {
 214        { P_XO, 0 },
 215        { P_NSS_CRYPTO_PLL, 1 },
 216        { P_GPLL0, 2 },
 217};
 218
 219static const char * const gcc_xo_ubi32_pll_gpll0_gpll2_gpll4_gpll6[] = {
 220        "xo",
 221        "ubi32_pll",
 222        "gpll0",
 223        "gpll2",
 224        "gpll4",
 225        "gpll6",
 226};
 227
 228static const struct parent_map gcc_xo_ubi32_gpll0_gpll2_gpll4_gpll6_map[] = {
 229        { P_XO, 0 },
 230        { P_UBI32_PLL, 1 },
 231        { P_GPLL0, 2 },
 232        { P_GPLL2, 3 },
 233        { P_GPLL4, 4 },
 234        { P_GPLL6, 5 },
 235};
 236
 237static const char * const gcc_xo_gpll0_out_main_div2[] = {
 238        "xo",
 239        "gpll0_out_main_div2",
 240};
 241
 242static const struct parent_map gcc_xo_gpll0_out_main_div2_map[] = {
 243        { P_XO, 0 },
 244        { P_GPLL0_DIV2, 1 },
 245};
 246
 247static const char * const gcc_xo_bias_gpll0_gpll4_nss_ubi32[] = {
 248        "xo",
 249        "bias_pll_cc_clk",
 250        "gpll0",
 251        "gpll4",
 252        "nss_crypto_pll",
 253        "ubi32_pll",
 254};
 255
 256static const struct parent_map gcc_xo_bias_gpll0_gpll4_nss_ubi32_map[] = {
 257        { P_XO, 0 },
 258        { P_BIAS_PLL, 1 },
 259        { P_GPLL0, 2 },
 260        { P_GPLL4, 3 },
 261        { P_NSS_CRYPTO_PLL, 4 },
 262        { P_UBI32_PLL, 5 },
 263};
 264
 265static const char * const gcc_xo_gpll0_gpll4[] = {
 266        "xo",
 267        "gpll0",
 268        "gpll4",
 269};
 270
 271static const struct parent_map gcc_xo_gpll0_gpll4_map[] = {
 272        { P_XO, 0 },
 273        { P_GPLL0, 1 },
 274        { P_GPLL4, 2 },
 275};
 276
 277static const char * const gcc_xo_uniphy0_rx_tx_ubi32_bias[] = {
 278        "xo",
 279        "uniphy0_gcc_rx_clk",
 280        "uniphy0_gcc_tx_clk",
 281        "ubi32_pll",
 282        "bias_pll_cc_clk",
 283};
 284
 285static const struct parent_map gcc_xo_uniphy0_rx_tx_ubi32_bias_map[] = {
 286        { P_XO, 0 },
 287        { P_UNIPHY0_RX, 1 },
 288        { P_UNIPHY0_TX, 2 },
 289        { P_UBI32_PLL, 5 },
 290        { P_BIAS_PLL, 6 },
 291};
 292
 293static const char * const gcc_xo_uniphy0_tx_rx_ubi32_bias[] = {
 294        "xo",
 295        "uniphy0_gcc_tx_clk",
 296        "uniphy0_gcc_rx_clk",
 297        "ubi32_pll",
 298        "bias_pll_cc_clk",
 299};
 300
 301static const struct parent_map gcc_xo_uniphy0_tx_rx_ubi32_bias_map[] = {
 302        { P_XO, 0 },
 303        { P_UNIPHY0_TX, 1 },
 304        { P_UNIPHY0_RX, 2 },
 305        { P_UBI32_PLL, 5 },
 306        { P_BIAS_PLL, 6 },
 307};
 308
 309static const char * const gcc_xo_uniphy0_rx_tx_uniphy1_rx_tx_ubi32_bias[] = {
 310        "xo",
 311        "uniphy0_gcc_rx_clk",
 312        "uniphy0_gcc_tx_clk",
 313        "uniphy1_gcc_rx_clk",
 314        "uniphy1_gcc_tx_clk",
 315        "ubi32_pll",
 316        "bias_pll_cc_clk",
 317};
 318
 319static const struct parent_map
 320gcc_xo_uniphy0_rx_tx_uniphy1_rx_tx_ubi32_bias_map[] = {
 321        { P_XO, 0 },
 322        { P_UNIPHY0_RX, 1 },
 323        { P_UNIPHY0_TX, 2 },
 324        { P_UNIPHY1_RX, 3 },
 325        { P_UNIPHY1_TX, 4 },
 326        { P_UBI32_PLL, 5 },
 327        { P_BIAS_PLL, 6 },
 328};
 329
 330static const char * const gcc_xo_uniphy0_tx_rx_uniphy1_tx_rx_ubi32_bias[] = {
 331        "xo",
 332        "uniphy0_gcc_tx_clk",
 333        "uniphy0_gcc_rx_clk",
 334        "uniphy1_gcc_tx_clk",
 335        "uniphy1_gcc_rx_clk",
 336        "ubi32_pll",
 337        "bias_pll_cc_clk",
 338};
 339
 340static const struct parent_map
 341gcc_xo_uniphy0_tx_rx_uniphy1_tx_rx_ubi32_bias_map[] = {
 342        { P_XO, 0 },
 343        { P_UNIPHY0_TX, 1 },
 344        { P_UNIPHY0_RX, 2 },
 345        { P_UNIPHY1_TX, 3 },
 346        { P_UNIPHY1_RX, 4 },
 347        { P_UBI32_PLL, 5 },
 348        { P_BIAS_PLL, 6 },
 349};
 350
 351static const char * const gcc_xo_uniphy2_rx_tx_ubi32_bias[] = {
 352        "xo",
 353        "uniphy2_gcc_rx_clk",
 354        "uniphy2_gcc_tx_clk",
 355        "ubi32_pll",
 356        "bias_pll_cc_clk",
 357};
 358
 359static const struct parent_map gcc_xo_uniphy2_rx_tx_ubi32_bias_map[] = {
 360        { P_XO, 0 },
 361        { P_UNIPHY2_RX, 1 },
 362        { P_UNIPHY2_TX, 2 },
 363        { P_UBI32_PLL, 5 },
 364        { P_BIAS_PLL, 6 },
 365};
 366
 367static const char * const gcc_xo_uniphy2_tx_rx_ubi32_bias[] = {
 368        "xo",
 369        "uniphy2_gcc_tx_clk",
 370        "uniphy2_gcc_rx_clk",
 371        "ubi32_pll",
 372        "bias_pll_cc_clk",
 373};
 374
 375static const struct parent_map gcc_xo_uniphy2_tx_rx_ubi32_bias_map[] = {
 376        { P_XO, 0 },
 377        { P_UNIPHY2_TX, 1 },
 378        { P_UNIPHY2_RX, 2 },
 379        { P_UBI32_PLL, 5 },
 380        { P_BIAS_PLL, 6 },
 381};
 382
 383static const char * const gcc_xo_gpll0_gpll6_gpll0_sleep_clk[] = {
 384        "xo",
 385        "gpll0",
 386        "gpll6",
 387        "gpll0_out_main_div2",
 388        "sleep_clk",
 389};
 390
 391static const struct parent_map gcc_xo_gpll0_gpll6_gpll0_sleep_clk_map[] = {
 392        { P_XO, 0 },
 393        { P_GPLL0, 1 },
 394        { P_GPLL6, 2 },
 395        { P_GPLL0_DIV2, 4 },
 396        { P_SLEEP_CLK, 6 },
 397};
 398
 399static struct clk_alpha_pll gpll0_main = {
 400        .offset = 0x21000,
 401        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
 402        .clkr = {
 403                .enable_reg = 0x0b000,
 404                .enable_mask = BIT(0),
 405                .hw.init = &(struct clk_init_data){
 406                        .name = "gpll0_main",
 407                        .parent_names = (const char *[]){
 408                                "xo"
 409                        },
 410                        .num_parents = 1,
 411                        .ops = &clk_alpha_pll_ops,
 412                },
 413        },
 414};
 415
 416static struct clk_fixed_factor gpll0_out_main_div2 = {
 417        .mult = 1,
 418        .div = 2,
 419        .hw.init = &(struct clk_init_data){
 420                .name = "gpll0_out_main_div2",
 421                .parent_names = (const char *[]){
 422                        "gpll0_main"
 423                },
 424                .num_parents = 1,
 425                .ops = &clk_fixed_factor_ops,
 426                .flags = CLK_SET_RATE_PARENT,
 427        },
 428};
 429
 430static struct clk_alpha_pll_postdiv gpll0 = {
 431        .offset = 0x21000,
 432        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
 433        .width = 4,
 434        .clkr.hw.init = &(struct clk_init_data){
 435                .name = "gpll0",
 436                .parent_names = (const char *[]){
 437                        "gpll0_main"
 438                },
 439                .num_parents = 1,
 440                .ops = &clk_alpha_pll_postdiv_ro_ops,
 441        },
 442};
 443
 444static struct clk_alpha_pll gpll2_main = {
 445        .offset = 0x4a000,
 446        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
 447        .clkr = {
 448                .enable_reg = 0x0b000,
 449                .enable_mask = BIT(2),
 450                .hw.init = &(struct clk_init_data){
 451                        .name = "gpll2_main",
 452                        .parent_names = (const char *[]){
 453                                "xo"
 454                        },
 455                        .num_parents = 1,
 456                        .ops = &clk_alpha_pll_ops,
 457                        .flags = CLK_IS_CRITICAL,
 458                },
 459        },
 460};
 461
 462static struct clk_alpha_pll_postdiv gpll2 = {
 463        .offset = 0x4a000,
 464        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
 465        .width = 4,
 466        .clkr.hw.init = &(struct clk_init_data){
 467                .name = "gpll2",
 468                .parent_names = (const char *[]){
 469                        "gpll2_main"
 470                },
 471                .num_parents = 1,
 472                .ops = &clk_alpha_pll_postdiv_ro_ops,
 473                .flags = CLK_SET_RATE_PARENT,
 474        },
 475};
 476
 477static struct clk_alpha_pll gpll4_main = {
 478        .offset = 0x24000,
 479        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
 480        .clkr = {
 481                .enable_reg = 0x0b000,
 482                .enable_mask = BIT(5),
 483                .hw.init = &(struct clk_init_data){
 484                        .name = "gpll4_main",
 485                        .parent_names = (const char *[]){
 486                                "xo"
 487                        },
 488                        .num_parents = 1,
 489                        .ops = &clk_alpha_pll_ops,
 490                        .flags = CLK_IS_CRITICAL,
 491                },
 492        },
 493};
 494
 495static struct clk_alpha_pll_postdiv gpll4 = {
 496        .offset = 0x24000,
 497        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
 498        .width = 4,
 499        .clkr.hw.init = &(struct clk_init_data){
 500                .name = "gpll4",
 501                .parent_names = (const char *[]){
 502                        "gpll4_main"
 503                },
 504                .num_parents = 1,
 505                .ops = &clk_alpha_pll_postdiv_ro_ops,
 506                .flags = CLK_SET_RATE_PARENT,
 507        },
 508};
 509
 510static struct clk_alpha_pll gpll6_main = {
 511        .offset = 0x37000,
 512        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_BRAMMO],
 513        .flags = SUPPORTS_DYNAMIC_UPDATE,
 514        .clkr = {
 515                .enable_reg = 0x0b000,
 516                .enable_mask = BIT(7),
 517                .hw.init = &(struct clk_init_data){
 518                        .name = "gpll6_main",
 519                        .parent_names = (const char *[]){
 520                                "xo"
 521                        },
 522                        .num_parents = 1,
 523                        .ops = &clk_alpha_pll_ops,
 524                        .flags = CLK_IS_CRITICAL,
 525                },
 526        },
 527};
 528
 529static struct clk_alpha_pll_postdiv gpll6 = {
 530        .offset = 0x37000,
 531        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_BRAMMO],
 532        .width = 2,
 533        .clkr.hw.init = &(struct clk_init_data){
 534                .name = "gpll6",
 535                .parent_names = (const char *[]){
 536                        "gpll6_main"
 537                },
 538                .num_parents = 1,
 539                .ops = &clk_alpha_pll_postdiv_ro_ops,
 540                .flags = CLK_SET_RATE_PARENT,
 541        },
 542};
 543
 544static struct clk_fixed_factor gpll6_out_main_div2 = {
 545        .mult = 1,
 546        .div = 2,
 547        .hw.init = &(struct clk_init_data){
 548                .name = "gpll6_out_main_div2",
 549                .parent_names = (const char *[]){
 550                        "gpll6_main"
 551                },
 552                .num_parents = 1,
 553                .ops = &clk_fixed_factor_ops,
 554                .flags = CLK_SET_RATE_PARENT,
 555        },
 556};
 557
 558static struct clk_alpha_pll ubi32_pll_main = {
 559        .offset = 0x25000,
 560        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_HUAYRA],
 561        .flags = SUPPORTS_DYNAMIC_UPDATE,
 562        .clkr = {
 563                .enable_reg = 0x0b000,
 564                .enable_mask = BIT(6),
 565                .hw.init = &(struct clk_init_data){
 566                        .name = "ubi32_pll_main",
 567                        .parent_names = (const char *[]){
 568                                "xo"
 569                        },
 570                        .num_parents = 1,
 571                        .ops = &clk_alpha_pll_huayra_ops,
 572                },
 573        },
 574};
 575
 576static struct clk_alpha_pll_postdiv ubi32_pll = {
 577        .offset = 0x25000,
 578        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_HUAYRA],
 579        .width = 2,
 580        .clkr.hw.init = &(struct clk_init_data){
 581                .name = "ubi32_pll",
 582                .parent_names = (const char *[]){
 583                        "ubi32_pll_main"
 584                },
 585                .num_parents = 1,
 586                .ops = &clk_alpha_pll_postdiv_ro_ops,
 587                .flags = CLK_SET_RATE_PARENT,
 588        },
 589};
 590
 591static struct clk_alpha_pll nss_crypto_pll_main = {
 592        .offset = 0x22000,
 593        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
 594        .clkr = {
 595                .enable_reg = 0x0b000,
 596                .enable_mask = BIT(4),
 597                .hw.init = &(struct clk_init_data){
 598                        .name = "nss_crypto_pll_main",
 599                        .parent_names = (const char *[]){
 600                                "xo"
 601                        },
 602                        .num_parents = 1,
 603                        .ops = &clk_alpha_pll_ops,
 604                },
 605        },
 606};
 607
 608static struct clk_alpha_pll_postdiv nss_crypto_pll = {
 609        .offset = 0x22000,
 610        .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
 611        .width = 4,
 612        .clkr.hw.init = &(struct clk_init_data){
 613                .name = "nss_crypto_pll",
 614                .parent_names = (const char *[]){
 615                        "nss_crypto_pll_main"
 616                },
 617                .num_parents = 1,
 618                .ops = &clk_alpha_pll_postdiv_ro_ops,
 619                .flags = CLK_SET_RATE_PARENT,
 620        },
 621};
 622
 623static const struct freq_tbl ftbl_pcnoc_bfdcd_clk_src[] = {
 624        F(19200000, P_XO, 1, 0, 0),
 625        F(50000000, P_GPLL0, 16, 0, 0),
 626        F(100000000, P_GPLL0, 8, 0, 0),
 627        { }
 628};
 629
 630static struct clk_rcg2 pcnoc_bfdcd_clk_src = {
 631        .cmd_rcgr = 0x27000,
 632        .freq_tbl = ftbl_pcnoc_bfdcd_clk_src,
 633        .hid_width = 5,
 634        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 635        .clkr.hw.init = &(struct clk_init_data){
 636                .name = "pcnoc_bfdcd_clk_src",
 637                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 638                .num_parents = 3,
 639                .ops = &clk_rcg2_ops,
 640                .flags = CLK_IS_CRITICAL,
 641        },
 642};
 643
 644static struct clk_fixed_factor pcnoc_clk_src = {
 645        .mult = 1,
 646        .div = 1,
 647        .hw.init = &(struct clk_init_data){
 648                .name = "pcnoc_clk_src",
 649                .parent_names = (const char *[]){
 650                        "pcnoc_bfdcd_clk_src"
 651                },
 652                .num_parents = 1,
 653                .ops = &clk_fixed_factor_ops,
 654                .flags = CLK_SET_RATE_PARENT,
 655        },
 656};
 657
 658static struct clk_branch gcc_sleep_clk_src = {
 659        .halt_reg = 0x30000,
 660        .clkr = {
 661                .enable_reg = 0x30000,
 662                .enable_mask = BIT(1),
 663                .hw.init = &(struct clk_init_data){
 664                        .name = "gcc_sleep_clk_src",
 665                        .parent_names = (const char *[]){
 666                                "sleep_clk"
 667                        },
 668                        .num_parents = 1,
 669                        .ops = &clk_branch2_ops,
 670                },
 671        },
 672};
 673
 674static const struct freq_tbl ftbl_blsp1_qup_i2c_apps_clk_src[] = {
 675        F(19200000, P_XO, 1, 0, 0),
 676        F(25000000, P_GPLL0_DIV2, 16, 0, 0),
 677        F(50000000, P_GPLL0, 16, 0, 0),
 678        { }
 679};
 680
 681static struct clk_rcg2 blsp1_qup1_i2c_apps_clk_src = {
 682        .cmd_rcgr = 0x0200c,
 683        .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
 684        .hid_width = 5,
 685        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 686        .clkr.hw.init = &(struct clk_init_data){
 687                .name = "blsp1_qup1_i2c_apps_clk_src",
 688                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 689                .num_parents = 3,
 690                .ops = &clk_rcg2_ops,
 691        },
 692};
 693
 694static const struct freq_tbl ftbl_blsp1_qup_spi_apps_clk_src[] = {
 695        F(960000, P_XO, 10, 1, 2),
 696        F(4800000, P_XO, 4, 0, 0),
 697        F(9600000, P_XO, 2, 0, 0),
 698        F(12500000, P_GPLL0_DIV2, 16, 1, 2),
 699        F(16000000, P_GPLL0, 10, 1, 5),
 700        F(19200000, P_XO, 1, 0, 0),
 701        F(25000000, P_GPLL0, 16, 1, 2),
 702        F(50000000, P_GPLL0, 16, 0, 0),
 703        { }
 704};
 705
 706static struct clk_rcg2 blsp1_qup1_spi_apps_clk_src = {
 707        .cmd_rcgr = 0x02024,
 708        .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
 709        .mnd_width = 8,
 710        .hid_width = 5,
 711        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 712        .clkr.hw.init = &(struct clk_init_data){
 713                .name = "blsp1_qup1_spi_apps_clk_src",
 714                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 715                .num_parents = 3,
 716                .ops = &clk_rcg2_ops,
 717        },
 718};
 719
 720static struct clk_rcg2 blsp1_qup2_i2c_apps_clk_src = {
 721        .cmd_rcgr = 0x03000,
 722        .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
 723        .hid_width = 5,
 724        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 725        .clkr.hw.init = &(struct clk_init_data){
 726                .name = "blsp1_qup2_i2c_apps_clk_src",
 727                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 728                .num_parents = 3,
 729                .ops = &clk_rcg2_ops,
 730        },
 731};
 732
 733static struct clk_rcg2 blsp1_qup2_spi_apps_clk_src = {
 734        .cmd_rcgr = 0x03014,
 735        .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
 736        .mnd_width = 8,
 737        .hid_width = 5,
 738        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 739        .clkr.hw.init = &(struct clk_init_data){
 740                .name = "blsp1_qup2_spi_apps_clk_src",
 741                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 742                .num_parents = 3,
 743                .ops = &clk_rcg2_ops,
 744        },
 745};
 746
 747static struct clk_rcg2 blsp1_qup3_i2c_apps_clk_src = {
 748        .cmd_rcgr = 0x04000,
 749        .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
 750        .hid_width = 5,
 751        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 752        .clkr.hw.init = &(struct clk_init_data){
 753                .name = "blsp1_qup3_i2c_apps_clk_src",
 754                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 755                .num_parents = 3,
 756                .ops = &clk_rcg2_ops,
 757        },
 758};
 759
 760static struct clk_rcg2 blsp1_qup3_spi_apps_clk_src = {
 761        .cmd_rcgr = 0x04014,
 762        .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
 763        .mnd_width = 8,
 764        .hid_width = 5,
 765        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 766        .clkr.hw.init = &(struct clk_init_data){
 767                .name = "blsp1_qup3_spi_apps_clk_src",
 768                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 769                .num_parents = 3,
 770                .ops = &clk_rcg2_ops,
 771        },
 772};
 773
 774static struct clk_rcg2 blsp1_qup4_i2c_apps_clk_src = {
 775        .cmd_rcgr = 0x05000,
 776        .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
 777        .hid_width = 5,
 778        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 779        .clkr.hw.init = &(struct clk_init_data){
 780                .name = "blsp1_qup4_i2c_apps_clk_src",
 781                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 782                .num_parents = 3,
 783                .ops = &clk_rcg2_ops,
 784        },
 785};
 786
 787static struct clk_rcg2 blsp1_qup4_spi_apps_clk_src = {
 788        .cmd_rcgr = 0x05014,
 789        .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
 790        .mnd_width = 8,
 791        .hid_width = 5,
 792        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 793        .clkr.hw.init = &(struct clk_init_data){
 794                .name = "blsp1_qup4_spi_apps_clk_src",
 795                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 796                .num_parents = 3,
 797                .ops = &clk_rcg2_ops,
 798        },
 799};
 800
 801static struct clk_rcg2 blsp1_qup5_i2c_apps_clk_src = {
 802        .cmd_rcgr = 0x06000,
 803        .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
 804        .hid_width = 5,
 805        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 806        .clkr.hw.init = &(struct clk_init_data){
 807                .name = "blsp1_qup5_i2c_apps_clk_src",
 808                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 809                .num_parents = 3,
 810                .ops = &clk_rcg2_ops,
 811        },
 812};
 813
 814static struct clk_rcg2 blsp1_qup5_spi_apps_clk_src = {
 815        .cmd_rcgr = 0x06014,
 816        .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
 817        .mnd_width = 8,
 818        .hid_width = 5,
 819        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 820        .clkr.hw.init = &(struct clk_init_data){
 821                .name = "blsp1_qup5_spi_apps_clk_src",
 822                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 823                .num_parents = 3,
 824                .ops = &clk_rcg2_ops,
 825        },
 826};
 827
 828static struct clk_rcg2 blsp1_qup6_i2c_apps_clk_src = {
 829        .cmd_rcgr = 0x07000,
 830        .freq_tbl = ftbl_blsp1_qup_i2c_apps_clk_src,
 831        .hid_width = 5,
 832        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 833        .clkr.hw.init = &(struct clk_init_data){
 834                .name = "blsp1_qup6_i2c_apps_clk_src",
 835                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 836                .num_parents = 3,
 837                .ops = &clk_rcg2_ops,
 838        },
 839};
 840
 841static struct clk_rcg2 blsp1_qup6_spi_apps_clk_src = {
 842        .cmd_rcgr = 0x07014,
 843        .freq_tbl = ftbl_blsp1_qup_spi_apps_clk_src,
 844        .mnd_width = 8,
 845        .hid_width = 5,
 846        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 847        .clkr.hw.init = &(struct clk_init_data){
 848                .name = "blsp1_qup6_spi_apps_clk_src",
 849                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 850                .num_parents = 3,
 851                .ops = &clk_rcg2_ops,
 852        },
 853};
 854
 855static const struct freq_tbl ftbl_blsp1_uart_apps_clk_src[] = {
 856        F(3686400, P_GPLL0_DIV2, 1, 144, 15625),
 857        F(7372800, P_GPLL0_DIV2, 1, 288, 15625),
 858        F(14745600, P_GPLL0_DIV2, 1, 576, 15625),
 859        F(16000000, P_GPLL0_DIV2, 5, 1, 5),
 860        F(19200000, P_XO, 1, 0, 0),
 861        F(24000000, P_GPLL0, 1, 3, 100),
 862        F(25000000, P_GPLL0, 16, 1, 2),
 863        F(32000000, P_GPLL0, 1, 1, 25),
 864        F(40000000, P_GPLL0, 1, 1, 20),
 865        F(46400000, P_GPLL0, 1, 29, 500),
 866        F(48000000, P_GPLL0, 1, 3, 50),
 867        F(51200000, P_GPLL0, 1, 8, 125),
 868        F(56000000, P_GPLL0, 1, 7, 100),
 869        F(58982400, P_GPLL0, 1, 1152, 15625),
 870        F(60000000, P_GPLL0, 1, 3, 40),
 871        F(64000000, P_GPLL0, 12.5, 1, 1),
 872        { }
 873};
 874
 875static struct clk_rcg2 blsp1_uart1_apps_clk_src = {
 876        .cmd_rcgr = 0x02044,
 877        .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
 878        .mnd_width = 16,
 879        .hid_width = 5,
 880        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 881        .clkr.hw.init = &(struct clk_init_data){
 882                .name = "blsp1_uart1_apps_clk_src",
 883                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 884                .num_parents = 3,
 885                .ops = &clk_rcg2_ops,
 886        },
 887};
 888
 889static struct clk_rcg2 blsp1_uart2_apps_clk_src = {
 890        .cmd_rcgr = 0x03034,
 891        .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
 892        .mnd_width = 16,
 893        .hid_width = 5,
 894        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 895        .clkr.hw.init = &(struct clk_init_data){
 896                .name = "blsp1_uart2_apps_clk_src",
 897                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 898                .num_parents = 3,
 899                .ops = &clk_rcg2_ops,
 900        },
 901};
 902
 903static struct clk_rcg2 blsp1_uart3_apps_clk_src = {
 904        .cmd_rcgr = 0x04034,
 905        .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
 906        .mnd_width = 16,
 907        .hid_width = 5,
 908        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 909        .clkr.hw.init = &(struct clk_init_data){
 910                .name = "blsp1_uart3_apps_clk_src",
 911                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 912                .num_parents = 3,
 913                .ops = &clk_rcg2_ops,
 914        },
 915};
 916
 917static struct clk_rcg2 blsp1_uart4_apps_clk_src = {
 918        .cmd_rcgr = 0x05034,
 919        .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
 920        .mnd_width = 16,
 921        .hid_width = 5,
 922        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 923        .clkr.hw.init = &(struct clk_init_data){
 924                .name = "blsp1_uart4_apps_clk_src",
 925                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 926                .num_parents = 3,
 927                .ops = &clk_rcg2_ops,
 928        },
 929};
 930
 931static struct clk_rcg2 blsp1_uart5_apps_clk_src = {
 932        .cmd_rcgr = 0x06034,
 933        .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
 934        .mnd_width = 16,
 935        .hid_width = 5,
 936        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 937        .clkr.hw.init = &(struct clk_init_data){
 938                .name = "blsp1_uart5_apps_clk_src",
 939                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 940                .num_parents = 3,
 941                .ops = &clk_rcg2_ops,
 942        },
 943};
 944
 945static struct clk_rcg2 blsp1_uart6_apps_clk_src = {
 946        .cmd_rcgr = 0x07034,
 947        .freq_tbl = ftbl_blsp1_uart_apps_clk_src,
 948        .mnd_width = 16,
 949        .hid_width = 5,
 950        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
 951        .clkr.hw.init = &(struct clk_init_data){
 952                .name = "blsp1_uart6_apps_clk_src",
 953                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
 954                .num_parents = 3,
 955                .ops = &clk_rcg2_ops,
 956        },
 957};
 958
 959static const struct freq_tbl ftbl_pcie_axi_clk_src[] = {
 960        F(19200000, P_XO, 1, 0, 0),
 961        F(200000000, P_GPLL0, 4, 0, 0),
 962        { }
 963};
 964
 965static struct clk_rcg2 pcie0_axi_clk_src = {
 966        .cmd_rcgr = 0x75054,
 967        .freq_tbl = ftbl_pcie_axi_clk_src,
 968        .hid_width = 5,
 969        .parent_map = gcc_xo_gpll0_map,
 970        .clkr.hw.init = &(struct clk_init_data){
 971                .name = "pcie0_axi_clk_src",
 972                .parent_names = gcc_xo_gpll0,
 973                .num_parents = 2,
 974                .ops = &clk_rcg2_ops,
 975        },
 976};
 977
 978static const struct freq_tbl ftbl_pcie_aux_clk_src[] = {
 979        F(19200000, P_XO, 1, 0, 0),
 980};
 981
 982static struct clk_rcg2 pcie0_aux_clk_src = {
 983        .cmd_rcgr = 0x75024,
 984        .freq_tbl = ftbl_pcie_aux_clk_src,
 985        .mnd_width = 16,
 986        .hid_width = 5,
 987        .parent_map = gcc_xo_gpll0_sleep_clk_map,
 988        .clkr.hw.init = &(struct clk_init_data){
 989                .name = "pcie0_aux_clk_src",
 990                .parent_names = gcc_xo_gpll0_sleep_clk,
 991                .num_parents = 3,
 992                .ops = &clk_rcg2_ops,
 993        },
 994};
 995
 996static struct clk_regmap_mux pcie0_pipe_clk_src = {
 997        .reg = 0x7501c,
 998        .shift = 8,
 999        .width = 2,
1000        .parent_map = gcc_pcie20_phy0_pipe_clk_xo_map,
1001        .clkr = {
1002                .hw.init = &(struct clk_init_data){
1003                        .name = "pcie0_pipe_clk_src",
1004                        .parent_names = gcc_pcie20_phy0_pipe_clk_xo,
1005                        .num_parents = 2,
1006                        .ops = &clk_regmap_mux_closest_ops,
1007                        .flags = CLK_SET_RATE_PARENT,
1008                },
1009        },
1010};
1011
1012static struct clk_rcg2 pcie1_axi_clk_src = {
1013        .cmd_rcgr = 0x76054,
1014        .freq_tbl = ftbl_pcie_axi_clk_src,
1015        .hid_width = 5,
1016        .parent_map = gcc_xo_gpll0_map,
1017        .clkr.hw.init = &(struct clk_init_data){
1018                .name = "pcie1_axi_clk_src",
1019                .parent_names = gcc_xo_gpll0,
1020                .num_parents = 2,
1021                .ops = &clk_rcg2_ops,
1022        },
1023};
1024
1025static struct clk_rcg2 pcie1_aux_clk_src = {
1026        .cmd_rcgr = 0x76024,
1027        .freq_tbl = ftbl_pcie_aux_clk_src,
1028        .mnd_width = 16,
1029        .hid_width = 5,
1030        .parent_map = gcc_xo_gpll0_sleep_clk_map,
1031        .clkr.hw.init = &(struct clk_init_data){
1032                .name = "pcie1_aux_clk_src",
1033                .parent_names = gcc_xo_gpll0_sleep_clk,
1034                .num_parents = 3,
1035                .ops = &clk_rcg2_ops,
1036        },
1037};
1038
1039static struct clk_regmap_mux pcie1_pipe_clk_src = {
1040        .reg = 0x7601c,
1041        .shift = 8,
1042        .width = 2,
1043        .parent_map = gcc_pcie20_phy1_pipe_clk_xo_map,
1044        .clkr = {
1045                .hw.init = &(struct clk_init_data){
1046                        .name = "pcie1_pipe_clk_src",
1047                        .parent_names = gcc_pcie20_phy1_pipe_clk_xo,
1048                        .num_parents = 2,
1049                        .ops = &clk_regmap_mux_closest_ops,
1050                        .flags = CLK_SET_RATE_PARENT,
1051                },
1052        },
1053};
1054
1055static const struct freq_tbl ftbl_sdcc_apps_clk_src[] = {
1056        F(144000, P_XO, 16, 3, 25),
1057        F(400000, P_XO, 12, 1, 4),
1058        F(24000000, P_GPLL2, 12, 1, 4),
1059        F(48000000, P_GPLL2, 12, 1, 2),
1060        F(96000000, P_GPLL2, 12, 0, 0),
1061        F(177777778, P_GPLL0, 4.5, 0, 0),
1062        F(192000000, P_GPLL2, 6, 0, 0),
1063        F(384000000, P_GPLL2, 3, 0, 0),
1064        { }
1065};
1066
1067static struct clk_rcg2 sdcc1_apps_clk_src = {
1068        .cmd_rcgr = 0x42004,
1069        .freq_tbl = ftbl_sdcc_apps_clk_src,
1070        .mnd_width = 8,
1071        .hid_width = 5,
1072        .parent_map = gcc_xo_gpll0_gpll2_gpll0_out_main_div2_map,
1073        .clkr.hw.init = &(struct clk_init_data){
1074                .name = "sdcc1_apps_clk_src",
1075                .parent_names = gcc_xo_gpll0_gpll2_gpll0_out_main_div2,
1076                .num_parents = 4,
1077                .ops = &clk_rcg2_ops,
1078        },
1079};
1080
1081static const struct freq_tbl ftbl_sdcc_ice_core_clk_src[] = {
1082        F(19200000, P_XO, 1, 0, 0),
1083        F(160000000, P_GPLL0, 5, 0, 0),
1084        F(308570000, P_GPLL6, 3.5, 0, 0),
1085};
1086
1087static struct clk_rcg2 sdcc1_ice_core_clk_src = {
1088        .cmd_rcgr = 0x5d000,
1089        .freq_tbl = ftbl_sdcc_ice_core_clk_src,
1090        .mnd_width = 8,
1091        .hid_width = 5,
1092        .parent_map = gcc_xo_gpll0_gpll6_gpll0_div2_map,
1093        .clkr.hw.init = &(struct clk_init_data){
1094                .name = "sdcc1_ice_core_clk_src",
1095                .parent_names = gcc_xo_gpll0_gpll6_gpll0_div2,
1096                .num_parents = 4,
1097                .ops = &clk_rcg2_ops,
1098        },
1099};
1100
1101static struct clk_rcg2 sdcc2_apps_clk_src = {
1102        .cmd_rcgr = 0x43004,
1103        .freq_tbl = ftbl_sdcc_apps_clk_src,
1104        .mnd_width = 8,
1105        .hid_width = 5,
1106        .parent_map = gcc_xo_gpll0_gpll2_gpll0_out_main_div2_map,
1107        .clkr.hw.init = &(struct clk_init_data){
1108                .name = "sdcc2_apps_clk_src",
1109                .parent_names = gcc_xo_gpll0_gpll2_gpll0_out_main_div2,
1110                .num_parents = 4,
1111                .ops = &clk_rcg2_floor_ops,
1112        },
1113};
1114
1115static const struct freq_tbl ftbl_usb_master_clk_src[] = {
1116        F(80000000, P_GPLL0_DIV2, 5, 0, 0),
1117        F(100000000, P_GPLL0, 8, 0, 0),
1118        F(133330000, P_GPLL0, 6, 0, 0),
1119        { }
1120};
1121
1122static struct clk_rcg2 usb0_master_clk_src = {
1123        .cmd_rcgr = 0x3e00c,
1124        .freq_tbl = ftbl_usb_master_clk_src,
1125        .mnd_width = 8,
1126        .hid_width = 5,
1127        .parent_map = gcc_xo_gpll0_out_main_div2_gpll0_map,
1128        .clkr.hw.init = &(struct clk_init_data){
1129                .name = "usb0_master_clk_src",
1130                .parent_names = gcc_xo_gpll0_out_main_div2_gpll0,
1131                .num_parents = 3,
1132                .ops = &clk_rcg2_ops,
1133        },
1134};
1135
1136static const struct freq_tbl ftbl_usb_aux_clk_src[] = {
1137        F(19200000, P_XO, 1, 0, 0),
1138        { }
1139};
1140
1141static struct clk_rcg2 usb0_aux_clk_src = {
1142        .cmd_rcgr = 0x3e05c,
1143        .freq_tbl = ftbl_usb_aux_clk_src,
1144        .mnd_width = 16,
1145        .hid_width = 5,
1146        .parent_map = gcc_xo_gpll0_sleep_clk_map,
1147        .clkr.hw.init = &(struct clk_init_data){
1148                .name = "usb0_aux_clk_src",
1149                .parent_names = gcc_xo_gpll0_sleep_clk,
1150                .num_parents = 3,
1151                .ops = &clk_rcg2_ops,
1152        },
1153};
1154
1155static const struct freq_tbl ftbl_usb_mock_utmi_clk_src[] = {
1156        F(19200000, P_XO, 1, 0, 0),
1157        F(20000000, P_GPLL6, 6, 1, 9),
1158        F(60000000, P_GPLL6, 6, 1, 3),
1159        { }
1160};
1161
1162static struct clk_rcg2 usb0_mock_utmi_clk_src = {
1163        .cmd_rcgr = 0x3e020,
1164        .freq_tbl = ftbl_usb_mock_utmi_clk_src,
1165        .mnd_width = 8,
1166        .hid_width = 5,
1167        .parent_map = gcc_xo_gpll6_gpll0_gpll0_out_main_div2_map,
1168        .clkr.hw.init = &(struct clk_init_data){
1169                .name = "usb0_mock_utmi_clk_src",
1170                .parent_names = gcc_xo_gpll6_gpll0_gpll0_out_main_div2,
1171                .num_parents = 4,
1172                .ops = &clk_rcg2_ops,
1173        },
1174};
1175
1176static struct clk_regmap_mux usb0_pipe_clk_src = {
1177        .reg = 0x3e048,
1178        .shift = 8,
1179        .width = 2,
1180        .parent_map = gcc_usb3phy_0_cc_pipe_clk_xo_map,
1181        .clkr = {
1182                .hw.init = &(struct clk_init_data){
1183                        .name = "usb0_pipe_clk_src",
1184                        .parent_names = gcc_usb3phy_0_cc_pipe_clk_xo,
1185                        .num_parents = 2,
1186                        .ops = &clk_regmap_mux_closest_ops,
1187                        .flags = CLK_SET_RATE_PARENT,
1188                },
1189        },
1190};
1191
1192static struct clk_rcg2 usb1_master_clk_src = {
1193        .cmd_rcgr = 0x3f00c,
1194        .freq_tbl = ftbl_usb_master_clk_src,
1195        .mnd_width = 8,
1196        .hid_width = 5,
1197        .parent_map = gcc_xo_gpll0_out_main_div2_gpll0_map,
1198        .clkr.hw.init = &(struct clk_init_data){
1199                .name = "usb1_master_clk_src",
1200                .parent_names = gcc_xo_gpll0_out_main_div2_gpll0,
1201                .num_parents = 3,
1202                .ops = &clk_rcg2_ops,
1203        },
1204};
1205
1206static struct clk_rcg2 usb1_aux_clk_src = {
1207        .cmd_rcgr = 0x3f05c,
1208        .freq_tbl = ftbl_usb_aux_clk_src,
1209        .mnd_width = 16,
1210        .hid_width = 5,
1211        .parent_map = gcc_xo_gpll0_sleep_clk_map,
1212        .clkr.hw.init = &(struct clk_init_data){
1213                .name = "usb1_aux_clk_src",
1214                .parent_names = gcc_xo_gpll0_sleep_clk,
1215                .num_parents = 3,
1216                .ops = &clk_rcg2_ops,
1217        },
1218};
1219
1220static struct clk_rcg2 usb1_mock_utmi_clk_src = {
1221        .cmd_rcgr = 0x3f020,
1222        .freq_tbl = ftbl_usb_mock_utmi_clk_src,
1223        .mnd_width = 8,
1224        .hid_width = 5,
1225        .parent_map = gcc_xo_gpll6_gpll0_gpll0_out_main_div2_map,
1226        .clkr.hw.init = &(struct clk_init_data){
1227                .name = "usb1_mock_utmi_clk_src",
1228                .parent_names = gcc_xo_gpll6_gpll0_gpll0_out_main_div2,
1229                .num_parents = 4,
1230                .ops = &clk_rcg2_ops,
1231        },
1232};
1233
1234static struct clk_regmap_mux usb1_pipe_clk_src = {
1235        .reg = 0x3f048,
1236        .shift = 8,
1237        .width = 2,
1238        .parent_map = gcc_usb3phy_1_cc_pipe_clk_xo_map,
1239        .clkr = {
1240                .hw.init = &(struct clk_init_data){
1241                        .name = "usb1_pipe_clk_src",
1242                        .parent_names = gcc_usb3phy_1_cc_pipe_clk_xo,
1243                        .num_parents = 2,
1244                        .ops = &clk_regmap_mux_closest_ops,
1245                        .flags = CLK_SET_RATE_PARENT,
1246                },
1247        },
1248};
1249
1250static struct clk_branch gcc_xo_clk_src = {
1251        .halt_reg = 0x30018,
1252        .clkr = {
1253                .enable_reg = 0x30018,
1254                .enable_mask = BIT(1),
1255                .hw.init = &(struct clk_init_data){
1256                        .name = "gcc_xo_clk_src",
1257                        .parent_names = (const char *[]){
1258                                "xo"
1259                        },
1260                        .num_parents = 1,
1261                        .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
1262                        .ops = &clk_branch2_ops,
1263                },
1264        },
1265};
1266
1267static struct clk_fixed_factor gcc_xo_div4_clk_src = {
1268        .mult = 1,
1269        .div = 4,
1270        .hw.init = &(struct clk_init_data){
1271                .name = "gcc_xo_div4_clk_src",
1272                .parent_names = (const char *[]){
1273                        "gcc_xo_clk_src"
1274                },
1275                .num_parents = 1,
1276                .ops = &clk_fixed_factor_ops,
1277                .flags = CLK_SET_RATE_PARENT,
1278        },
1279};
1280
1281static const struct freq_tbl ftbl_system_noc_bfdcd_clk_src[] = {
1282        F(19200000, P_XO, 1, 0, 0),
1283        F(50000000, P_GPLL0_DIV2, 8, 0, 0),
1284        F(100000000, P_GPLL0, 8, 0, 0),
1285        F(133333333, P_GPLL0, 6, 0, 0),
1286        F(160000000, P_GPLL0, 5, 0, 0),
1287        F(200000000, P_GPLL0, 4, 0, 0),
1288        F(266666667, P_GPLL0, 3, 0, 0),
1289        { }
1290};
1291
1292static struct clk_rcg2 system_noc_bfdcd_clk_src = {
1293        .cmd_rcgr = 0x26004,
1294        .freq_tbl = ftbl_system_noc_bfdcd_clk_src,
1295        .hid_width = 5,
1296        .parent_map = gcc_xo_gpll0_gpll6_gpll0_out_main_div2_map,
1297        .clkr.hw.init = &(struct clk_init_data){
1298                .name = "system_noc_bfdcd_clk_src",
1299                .parent_names = gcc_xo_gpll0_gpll6_gpll0_out_main_div2,
1300                .num_parents = 4,
1301                .ops = &clk_rcg2_ops,
1302                .flags = CLK_IS_CRITICAL,
1303        },
1304};
1305
1306static struct clk_fixed_factor system_noc_clk_src = {
1307        .mult = 1,
1308        .div = 1,
1309        .hw.init = &(struct clk_init_data){
1310                .name = "system_noc_clk_src",
1311                .parent_names = (const char *[]){
1312                        "system_noc_bfdcd_clk_src"
1313                },
1314                .num_parents = 1,
1315                .ops = &clk_fixed_factor_ops,
1316                .flags = CLK_SET_RATE_PARENT,
1317        },
1318};
1319
1320static const struct freq_tbl ftbl_nss_ce_clk_src[] = {
1321        F(19200000, P_XO, 1, 0, 0),
1322        F(200000000, P_GPLL0, 4, 0, 0),
1323        { }
1324};
1325
1326static struct clk_rcg2 nss_ce_clk_src = {
1327        .cmd_rcgr = 0x68098,
1328        .freq_tbl = ftbl_nss_ce_clk_src,
1329        .hid_width = 5,
1330        .parent_map = gcc_xo_gpll0_map,
1331        .clkr.hw.init = &(struct clk_init_data){
1332                .name = "nss_ce_clk_src",
1333                .parent_names = gcc_xo_gpll0,
1334                .num_parents = 2,
1335                .ops = &clk_rcg2_ops,
1336        },
1337};
1338
1339static const struct freq_tbl ftbl_nss_noc_bfdcd_clk_src[] = {
1340        F(19200000, P_XO, 1, 0, 0),
1341        F(461500000, P_BIAS_PLL_NSS_NOC, 1, 0, 0),
1342        { }
1343};
1344
1345static struct clk_rcg2 nss_noc_bfdcd_clk_src = {
1346        .cmd_rcgr = 0x68088,
1347        .freq_tbl = ftbl_nss_noc_bfdcd_clk_src,
1348        .hid_width = 5,
1349        .parent_map = gcc_xo_bias_pll_nss_noc_clk_gpll0_gpll2_map,
1350        .clkr.hw.init = &(struct clk_init_data){
1351                .name = "nss_noc_bfdcd_clk_src",
1352                .parent_names = gcc_xo_bias_pll_nss_noc_clk_gpll0_gpll2,
1353                .num_parents = 4,
1354                .ops = &clk_rcg2_ops,
1355        },
1356};
1357
1358static struct clk_fixed_factor nss_noc_clk_src = {
1359        .mult = 1,
1360        .div = 1,
1361        .hw.init = &(struct clk_init_data){
1362                .name = "nss_noc_clk_src",
1363                .parent_names = (const char *[]){
1364                        "nss_noc_bfdcd_clk_src"
1365                },
1366                .num_parents = 1,
1367                .ops = &clk_fixed_factor_ops,
1368                .flags = CLK_SET_RATE_PARENT,
1369        },
1370};
1371
1372static const struct freq_tbl ftbl_nss_crypto_clk_src[] = {
1373        F(19200000, P_XO, 1, 0, 0),
1374        F(600000000, P_NSS_CRYPTO_PLL, 1, 0, 0),
1375        { }
1376};
1377
1378static struct clk_rcg2 nss_crypto_clk_src = {
1379        .cmd_rcgr = 0x68144,
1380        .freq_tbl = ftbl_nss_crypto_clk_src,
1381        .mnd_width = 16,
1382        .hid_width = 5,
1383        .parent_map = gcc_xo_nss_crypto_pll_gpll0_map,
1384        .clkr.hw.init = &(struct clk_init_data){
1385                .name = "nss_crypto_clk_src",
1386                .parent_names = gcc_xo_nss_crypto_pll_gpll0,
1387                .num_parents = 3,
1388                .ops = &clk_rcg2_ops,
1389        },
1390};
1391
1392static const struct freq_tbl ftbl_nss_ubi_clk_src[] = {
1393        F(19200000, P_XO, 1, 0, 0),
1394        F(187200000, P_UBI32_PLL, 8, 0, 0),
1395        F(748800000, P_UBI32_PLL, 2, 0, 0),
1396        F(1497600000, P_UBI32_PLL, 1, 0, 0),
1397        F(1689600000, P_UBI32_PLL, 1, 0, 0),
1398        { }
1399};
1400
1401static struct clk_rcg2 nss_ubi0_clk_src = {
1402        .cmd_rcgr = 0x68104,
1403        .freq_tbl = ftbl_nss_ubi_clk_src,
1404        .hid_width = 5,
1405        .parent_map = gcc_xo_ubi32_gpll0_gpll2_gpll4_gpll6_map,
1406        .clkr.hw.init = &(struct clk_init_data){
1407                .name = "nss_ubi0_clk_src",
1408                .parent_names = gcc_xo_ubi32_pll_gpll0_gpll2_gpll4_gpll6,
1409                .num_parents = 6,
1410                .ops = &clk_rcg2_ops,
1411                .flags = CLK_SET_RATE_PARENT,
1412        },
1413};
1414
1415static struct clk_regmap_div nss_ubi0_div_clk_src = {
1416        .reg = 0x68118,
1417        .shift = 0,
1418        .width = 4,
1419        .clkr = {
1420                .hw.init = &(struct clk_init_data){
1421                        .name = "nss_ubi0_div_clk_src",
1422                        .parent_names = (const char *[]){
1423                                "nss_ubi0_clk_src"
1424                        },
1425                        .num_parents = 1,
1426                        .ops = &clk_regmap_div_ro_ops,
1427                        .flags = CLK_SET_RATE_PARENT,
1428                },
1429        },
1430};
1431
1432static struct clk_rcg2 nss_ubi1_clk_src = {
1433        .cmd_rcgr = 0x68124,
1434        .freq_tbl = ftbl_nss_ubi_clk_src,
1435        .hid_width = 5,
1436        .parent_map = gcc_xo_ubi32_gpll0_gpll2_gpll4_gpll6_map,
1437        .clkr.hw.init = &(struct clk_init_data){
1438                .name = "nss_ubi1_clk_src",
1439                .parent_names = gcc_xo_ubi32_pll_gpll0_gpll2_gpll4_gpll6,
1440                .num_parents = 6,
1441                .ops = &clk_rcg2_ops,
1442                .flags = CLK_SET_RATE_PARENT,
1443        },
1444};
1445
1446static struct clk_regmap_div nss_ubi1_div_clk_src = {
1447        .reg = 0x68138,
1448        .shift = 0,
1449        .width = 4,
1450        .clkr = {
1451                .hw.init = &(struct clk_init_data){
1452                        .name = "nss_ubi1_div_clk_src",
1453                        .parent_names = (const char *[]){
1454                                "nss_ubi1_clk_src"
1455                        },
1456                        .num_parents = 1,
1457                        .ops = &clk_regmap_div_ro_ops,
1458                        .flags = CLK_SET_RATE_PARENT,
1459                },
1460        },
1461};
1462
1463static const struct freq_tbl ftbl_ubi_mpt_clk_src[] = {
1464        F(19200000, P_XO, 1, 0, 0),
1465        F(25000000, P_GPLL0_DIV2, 16, 0, 0),
1466        { }
1467};
1468
1469static struct clk_rcg2 ubi_mpt_clk_src = {
1470        .cmd_rcgr = 0x68090,
1471        .freq_tbl = ftbl_ubi_mpt_clk_src,
1472        .hid_width = 5,
1473        .parent_map = gcc_xo_gpll0_out_main_div2_map,
1474        .clkr.hw.init = &(struct clk_init_data){
1475                .name = "ubi_mpt_clk_src",
1476                .parent_names = gcc_xo_gpll0_out_main_div2,
1477                .num_parents = 2,
1478                .ops = &clk_rcg2_ops,
1479        },
1480};
1481
1482static const struct freq_tbl ftbl_nss_imem_clk_src[] = {
1483        F(19200000, P_XO, 1, 0, 0),
1484        F(400000000, P_GPLL0, 2, 0, 0),
1485        { }
1486};
1487
1488static struct clk_rcg2 nss_imem_clk_src = {
1489        .cmd_rcgr = 0x68158,
1490        .freq_tbl = ftbl_nss_imem_clk_src,
1491        .hid_width = 5,
1492        .parent_map = gcc_xo_gpll0_gpll4_map,
1493        .clkr.hw.init = &(struct clk_init_data){
1494                .name = "nss_imem_clk_src",
1495                .parent_names = gcc_xo_gpll0_gpll4,
1496                .num_parents = 3,
1497                .ops = &clk_rcg2_ops,
1498        },
1499};
1500
1501static const struct freq_tbl ftbl_nss_ppe_clk_src[] = {
1502        F(19200000, P_XO, 1, 0, 0),
1503        F(300000000, P_BIAS_PLL, 1, 0, 0),
1504        { }
1505};
1506
1507static struct clk_rcg2 nss_ppe_clk_src = {
1508        .cmd_rcgr = 0x68080,
1509        .freq_tbl = ftbl_nss_ppe_clk_src,
1510        .hid_width = 5,
1511        .parent_map = gcc_xo_bias_gpll0_gpll4_nss_ubi32_map,
1512        .clkr.hw.init = &(struct clk_init_data){
1513                .name = "nss_ppe_clk_src",
1514                .parent_names = gcc_xo_bias_gpll0_gpll4_nss_ubi32,
1515                .num_parents = 6,
1516                .ops = &clk_rcg2_ops,
1517        },
1518};
1519
1520static struct clk_fixed_factor nss_ppe_cdiv_clk_src = {
1521        .mult = 1,
1522        .div = 4,
1523        .hw.init = &(struct clk_init_data){
1524                .name = "nss_ppe_cdiv_clk_src",
1525                .parent_names = (const char *[]){
1526                        "nss_ppe_clk_src"
1527                },
1528                .num_parents = 1,
1529                .ops = &clk_fixed_factor_ops,
1530                .flags = CLK_SET_RATE_PARENT,
1531        },
1532};
1533
1534static const struct freq_tbl ftbl_nss_port1_rx_clk_src[] = {
1535        F(19200000, P_XO, 1, 0, 0),
1536        F(25000000, P_UNIPHY0_RX, 5, 0, 0),
1537        F(125000000, P_UNIPHY0_RX, 1, 0, 0),
1538        { }
1539};
1540
1541static struct clk_rcg2 nss_port1_rx_clk_src = {
1542        .cmd_rcgr = 0x68020,
1543        .freq_tbl = ftbl_nss_port1_rx_clk_src,
1544        .hid_width = 5,
1545        .parent_map = gcc_xo_uniphy0_rx_tx_ubi32_bias_map,
1546        .clkr.hw.init = &(struct clk_init_data){
1547                .name = "nss_port1_rx_clk_src",
1548                .parent_names = gcc_xo_uniphy0_rx_tx_ubi32_bias,
1549                .num_parents = 5,
1550                .ops = &clk_rcg2_ops,
1551        },
1552};
1553
1554static struct clk_regmap_div nss_port1_rx_div_clk_src = {
1555        .reg = 0x68400,
1556        .shift = 0,
1557        .width = 4,
1558        .clkr = {
1559                .hw.init = &(struct clk_init_data){
1560                        .name = "nss_port1_rx_div_clk_src",
1561                        .parent_names = (const char *[]){
1562                                "nss_port1_rx_clk_src"
1563                        },
1564                        .num_parents = 1,
1565                        .ops = &clk_regmap_div_ops,
1566                        .flags = CLK_SET_RATE_PARENT,
1567                },
1568        },
1569};
1570
1571static const struct freq_tbl ftbl_nss_port1_tx_clk_src[] = {
1572        F(19200000, P_XO, 1, 0, 0),
1573        F(25000000, P_UNIPHY0_TX, 5, 0, 0),
1574        F(125000000, P_UNIPHY0_TX, 1, 0, 0),
1575        { }
1576};
1577
1578static struct clk_rcg2 nss_port1_tx_clk_src = {
1579        .cmd_rcgr = 0x68028,
1580        .freq_tbl = ftbl_nss_port1_tx_clk_src,
1581        .hid_width = 5,
1582        .parent_map = gcc_xo_uniphy0_tx_rx_ubi32_bias_map,
1583        .clkr.hw.init = &(struct clk_init_data){
1584                .name = "nss_port1_tx_clk_src",
1585                .parent_names = gcc_xo_uniphy0_tx_rx_ubi32_bias,
1586                .num_parents = 5,
1587                .ops = &clk_rcg2_ops,
1588        },
1589};
1590
1591static struct clk_regmap_div nss_port1_tx_div_clk_src = {
1592        .reg = 0x68404,
1593        .shift = 0,
1594        .width = 4,
1595        .clkr = {
1596                .hw.init = &(struct clk_init_data){
1597                        .name = "nss_port1_tx_div_clk_src",
1598                        .parent_names = (const char *[]){
1599                                "nss_port1_tx_clk_src"
1600                        },
1601                        .num_parents = 1,
1602                        .ops = &clk_regmap_div_ops,
1603                        .flags = CLK_SET_RATE_PARENT,
1604                },
1605        },
1606};
1607
1608static struct clk_rcg2 nss_port2_rx_clk_src = {
1609        .cmd_rcgr = 0x68030,
1610        .freq_tbl = ftbl_nss_port1_rx_clk_src,
1611        .hid_width = 5,
1612        .parent_map = gcc_xo_uniphy0_rx_tx_ubi32_bias_map,
1613        .clkr.hw.init = &(struct clk_init_data){
1614                .name = "nss_port2_rx_clk_src",
1615                .parent_names = gcc_xo_uniphy0_rx_tx_ubi32_bias,
1616                .num_parents = 5,
1617                .ops = &clk_rcg2_ops,
1618        },
1619};
1620
1621static struct clk_regmap_div nss_port2_rx_div_clk_src = {
1622        .reg = 0x68410,
1623        .shift = 0,
1624        .width = 4,
1625        .clkr = {
1626                .hw.init = &(struct clk_init_data){
1627                        .name = "nss_port2_rx_div_clk_src",
1628                        .parent_names = (const char *[]){
1629                                "nss_port2_rx_clk_src"
1630                        },
1631                        .num_parents = 1,
1632                        .ops = &clk_regmap_div_ops,
1633                        .flags = CLK_SET_RATE_PARENT,
1634                },
1635        },
1636};
1637
1638static struct clk_rcg2 nss_port2_tx_clk_src = {
1639        .cmd_rcgr = 0x68038,
1640        .freq_tbl = ftbl_nss_port1_tx_clk_src,
1641        .hid_width = 5,
1642        .parent_map = gcc_xo_uniphy0_tx_rx_ubi32_bias_map,
1643        .clkr.hw.init = &(struct clk_init_data){
1644                .name = "nss_port2_tx_clk_src",
1645                .parent_names = gcc_xo_uniphy0_tx_rx_ubi32_bias,
1646                .num_parents = 5,
1647                .ops = &clk_rcg2_ops,
1648        },
1649};
1650
1651static struct clk_regmap_div nss_port2_tx_div_clk_src = {
1652        .reg = 0x68414,
1653        .shift = 0,
1654        .width = 4,
1655        .clkr = {
1656                .hw.init = &(struct clk_init_data){
1657                        .name = "nss_port2_tx_div_clk_src",
1658                        .parent_names = (const char *[]){
1659                                "nss_port2_tx_clk_src"
1660                        },
1661                        .num_parents = 1,
1662                        .ops = &clk_regmap_div_ops,
1663                        .flags = CLK_SET_RATE_PARENT,
1664                },
1665        },
1666};
1667
1668static struct clk_rcg2 nss_port3_rx_clk_src = {
1669        .cmd_rcgr = 0x68040,
1670        .freq_tbl = ftbl_nss_port1_rx_clk_src,
1671        .hid_width = 5,
1672        .parent_map = gcc_xo_uniphy0_rx_tx_ubi32_bias_map,
1673        .clkr.hw.init = &(struct clk_init_data){
1674                .name = "nss_port3_rx_clk_src",
1675                .parent_names = gcc_xo_uniphy0_rx_tx_ubi32_bias,
1676                .num_parents = 5,
1677                .ops = &clk_rcg2_ops,
1678        },
1679};
1680
1681static struct clk_regmap_div nss_port3_rx_div_clk_src = {
1682        .reg = 0x68420,
1683        .shift = 0,
1684        .width = 4,
1685        .clkr = {
1686                .hw.init = &(struct clk_init_data){
1687                        .name = "nss_port3_rx_div_clk_src",
1688                        .parent_names = (const char *[]){
1689                                "nss_port3_rx_clk_src"
1690                        },
1691                        .num_parents = 1,
1692                        .ops = &clk_regmap_div_ops,
1693                        .flags = CLK_SET_RATE_PARENT,
1694                },
1695        },
1696};
1697
1698static struct clk_rcg2 nss_port3_tx_clk_src = {
1699        .cmd_rcgr = 0x68048,
1700        .freq_tbl = ftbl_nss_port1_tx_clk_src,
1701        .hid_width = 5,
1702        .parent_map = gcc_xo_uniphy0_tx_rx_ubi32_bias_map,
1703        .clkr.hw.init = &(struct clk_init_data){
1704                .name = "nss_port3_tx_clk_src",
1705                .parent_names = gcc_xo_uniphy0_tx_rx_ubi32_bias,
1706                .num_parents = 5,
1707                .ops = &clk_rcg2_ops,
1708        },
1709};
1710
1711static struct clk_regmap_div nss_port3_tx_div_clk_src = {
1712        .reg = 0x68424,
1713        .shift = 0,
1714        .width = 4,
1715        .clkr = {
1716                .hw.init = &(struct clk_init_data){
1717                        .name = "nss_port3_tx_div_clk_src",
1718                        .parent_names = (const char *[]){
1719                                "nss_port3_tx_clk_src"
1720                        },
1721                        .num_parents = 1,
1722                        .ops = &clk_regmap_div_ops,
1723                        .flags = CLK_SET_RATE_PARENT,
1724                },
1725        },
1726};
1727
1728static struct clk_rcg2 nss_port4_rx_clk_src = {
1729        .cmd_rcgr = 0x68050,
1730        .freq_tbl = ftbl_nss_port1_rx_clk_src,
1731        .hid_width = 5,
1732        .parent_map = gcc_xo_uniphy0_rx_tx_ubi32_bias_map,
1733        .clkr.hw.init = &(struct clk_init_data){
1734                .name = "nss_port4_rx_clk_src",
1735                .parent_names = gcc_xo_uniphy0_rx_tx_ubi32_bias,
1736                .num_parents = 5,
1737                .ops = &clk_rcg2_ops,
1738        },
1739};
1740
1741static struct clk_regmap_div nss_port4_rx_div_clk_src = {
1742        .reg = 0x68430,
1743        .shift = 0,
1744        .width = 4,
1745        .clkr = {
1746                .hw.init = &(struct clk_init_data){
1747                        .name = "nss_port4_rx_div_clk_src",
1748                        .parent_names = (const char *[]){
1749                                "nss_port4_rx_clk_src"
1750                        },
1751                        .num_parents = 1,
1752                        .ops = &clk_regmap_div_ops,
1753                        .flags = CLK_SET_RATE_PARENT,
1754                },
1755        },
1756};
1757
1758static struct clk_rcg2 nss_port4_tx_clk_src = {
1759        .cmd_rcgr = 0x68058,
1760        .freq_tbl = ftbl_nss_port1_tx_clk_src,
1761        .hid_width = 5,
1762        .parent_map = gcc_xo_uniphy0_tx_rx_ubi32_bias_map,
1763        .clkr.hw.init = &(struct clk_init_data){
1764                .name = "nss_port4_tx_clk_src",
1765                .parent_names = gcc_xo_uniphy0_tx_rx_ubi32_bias,
1766                .num_parents = 5,
1767                .ops = &clk_rcg2_ops,
1768        },
1769};
1770
1771static struct clk_regmap_div nss_port4_tx_div_clk_src = {
1772        .reg = 0x68434,
1773        .shift = 0,
1774        .width = 4,
1775        .clkr = {
1776                .hw.init = &(struct clk_init_data){
1777                        .name = "nss_port4_tx_div_clk_src",
1778                        .parent_names = (const char *[]){
1779                                "nss_port4_tx_clk_src"
1780                        },
1781                        .num_parents = 1,
1782                        .ops = &clk_regmap_div_ops,
1783                        .flags = CLK_SET_RATE_PARENT,
1784                },
1785        },
1786};
1787
1788static const struct freq_tbl ftbl_nss_port5_rx_clk_src[] = {
1789        F(19200000, P_XO, 1, 0, 0),
1790        F(25000000, P_UNIPHY1_RX, 12.5, 0, 0),
1791        F(78125000, P_UNIPHY1_RX, 4, 0, 0),
1792        F(125000000, P_UNIPHY1_RX, 2.5, 0, 0),
1793        F(156250000, P_UNIPHY1_RX, 2, 0, 0),
1794        F(312500000, P_UNIPHY1_RX, 1, 0, 0),
1795        { }
1796};
1797
1798static struct clk_rcg2 nss_port5_rx_clk_src = {
1799        .cmd_rcgr = 0x68060,
1800        .freq_tbl = ftbl_nss_port5_rx_clk_src,
1801        .hid_width = 5,
1802        .parent_map = gcc_xo_uniphy0_rx_tx_uniphy1_rx_tx_ubi32_bias_map,
1803        .clkr.hw.init = &(struct clk_init_data){
1804                .name = "nss_port5_rx_clk_src",
1805                .parent_names = gcc_xo_uniphy0_rx_tx_uniphy1_rx_tx_ubi32_bias,
1806                .num_parents = 7,
1807                .ops = &clk_rcg2_ops,
1808        },
1809};
1810
1811static struct clk_regmap_div nss_port5_rx_div_clk_src = {
1812        .reg = 0x68440,
1813        .shift = 0,
1814        .width = 4,
1815        .clkr = {
1816                .hw.init = &(struct clk_init_data){
1817                        .name = "nss_port5_rx_div_clk_src",
1818                        .parent_names = (const char *[]){
1819                                "nss_port5_rx_clk_src"
1820                        },
1821                        .num_parents = 1,
1822                        .ops = &clk_regmap_div_ops,
1823                        .flags = CLK_SET_RATE_PARENT,
1824                },
1825        },
1826};
1827
1828static const struct freq_tbl ftbl_nss_port5_tx_clk_src[] = {
1829        F(19200000, P_XO, 1, 0, 0),
1830        F(25000000, P_UNIPHY1_TX, 12.5, 0, 0),
1831        F(78125000, P_UNIPHY1_TX, 4, 0, 0),
1832        F(125000000, P_UNIPHY1_TX, 2.5, 0, 0),
1833        F(156250000, P_UNIPHY1_TX, 2, 0, 0),
1834        F(312500000, P_UNIPHY1_TX, 1, 0, 0),
1835        { }
1836};
1837
1838static struct clk_rcg2 nss_port5_tx_clk_src = {
1839        .cmd_rcgr = 0x68068,
1840        .freq_tbl = ftbl_nss_port5_tx_clk_src,
1841        .hid_width = 5,
1842        .parent_map = gcc_xo_uniphy0_tx_rx_uniphy1_tx_rx_ubi32_bias_map,
1843        .clkr.hw.init = &(struct clk_init_data){
1844                .name = "nss_port5_tx_clk_src",
1845                .parent_names = gcc_xo_uniphy0_tx_rx_uniphy1_tx_rx_ubi32_bias,
1846                .num_parents = 7,
1847                .ops = &clk_rcg2_ops,
1848        },
1849};
1850
1851static struct clk_regmap_div nss_port5_tx_div_clk_src = {
1852        .reg = 0x68444,
1853        .shift = 0,
1854        .width = 4,
1855        .clkr = {
1856                .hw.init = &(struct clk_init_data){
1857                        .name = "nss_port5_tx_div_clk_src",
1858                        .parent_names = (const char *[]){
1859                                "nss_port5_tx_clk_src"
1860                        },
1861                        .num_parents = 1,
1862                        .ops = &clk_regmap_div_ops,
1863                        .flags = CLK_SET_RATE_PARENT,
1864                },
1865        },
1866};
1867
1868static const struct freq_tbl ftbl_nss_port6_rx_clk_src[] = {
1869        F(19200000, P_XO, 1, 0, 0),
1870        F(25000000, P_UNIPHY2_RX, 12.5, 0, 0),
1871        F(78125000, P_UNIPHY2_RX, 4, 0, 0),
1872        F(125000000, P_UNIPHY2_RX, 2.5, 0, 0),
1873        F(156250000, P_UNIPHY2_RX, 2, 0, 0),
1874        F(312500000, P_UNIPHY2_RX, 1, 0, 0),
1875        { }
1876};
1877
1878static struct clk_rcg2 nss_port6_rx_clk_src = {
1879        .cmd_rcgr = 0x68070,
1880        .freq_tbl = ftbl_nss_port6_rx_clk_src,
1881        .hid_width = 5,
1882        .parent_map = gcc_xo_uniphy2_rx_tx_ubi32_bias_map,
1883        .clkr.hw.init = &(struct clk_init_data){
1884                .name = "nss_port6_rx_clk_src",
1885                .parent_names = gcc_xo_uniphy2_rx_tx_ubi32_bias,
1886                .num_parents = 5,
1887                .ops = &clk_rcg2_ops,
1888        },
1889};
1890
1891static struct clk_regmap_div nss_port6_rx_div_clk_src = {
1892        .reg = 0x68450,
1893        .shift = 0,
1894        .width = 4,
1895        .clkr = {
1896                .hw.init = &(struct clk_init_data){
1897                        .name = "nss_port6_rx_div_clk_src",
1898                        .parent_names = (const char *[]){
1899                                "nss_port6_rx_clk_src"
1900                        },
1901                        .num_parents = 1,
1902                        .ops = &clk_regmap_div_ops,
1903                        .flags = CLK_SET_RATE_PARENT,
1904                },
1905        },
1906};
1907
1908static const struct freq_tbl ftbl_nss_port6_tx_clk_src[] = {
1909        F(19200000, P_XO, 1, 0, 0),
1910        F(25000000, P_UNIPHY2_TX, 12.5, 0, 0),
1911        F(78125000, P_UNIPHY2_TX, 4, 0, 0),
1912        F(125000000, P_UNIPHY2_TX, 2.5, 0, 0),
1913        F(156250000, P_UNIPHY2_TX, 2, 0, 0),
1914        F(312500000, P_UNIPHY2_TX, 1, 0, 0),
1915        { }
1916};
1917
1918static struct clk_rcg2 nss_port6_tx_clk_src = {
1919        .cmd_rcgr = 0x68078,
1920        .freq_tbl = ftbl_nss_port6_tx_clk_src,
1921        .hid_width = 5,
1922        .parent_map = gcc_xo_uniphy2_tx_rx_ubi32_bias_map,
1923        .clkr.hw.init = &(struct clk_init_data){
1924                .name = "nss_port6_tx_clk_src",
1925                .parent_names = gcc_xo_uniphy2_tx_rx_ubi32_bias,
1926                .num_parents = 5,
1927                .ops = &clk_rcg2_ops,
1928        },
1929};
1930
1931static struct clk_regmap_div nss_port6_tx_div_clk_src = {
1932        .reg = 0x68454,
1933        .shift = 0,
1934        .width = 4,
1935        .clkr = {
1936                .hw.init = &(struct clk_init_data){
1937                        .name = "nss_port6_tx_div_clk_src",
1938                        .parent_names = (const char *[]){
1939                                "nss_port6_tx_clk_src"
1940                        },
1941                        .num_parents = 1,
1942                        .ops = &clk_regmap_div_ops,
1943                        .flags = CLK_SET_RATE_PARENT,
1944                },
1945        },
1946};
1947
1948static struct freq_tbl ftbl_crypto_clk_src[] = {
1949        F(40000000, P_GPLL0_DIV2, 10, 0, 0),
1950        F(80000000, P_GPLL0, 10, 0, 0),
1951        F(100000000, P_GPLL0, 8, 0, 0),
1952        F(160000000, P_GPLL0, 5, 0, 0),
1953        { }
1954};
1955
1956static struct clk_rcg2 crypto_clk_src = {
1957        .cmd_rcgr = 0x16004,
1958        .freq_tbl = ftbl_crypto_clk_src,
1959        .hid_width = 5,
1960        .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map,
1961        .clkr.hw.init = &(struct clk_init_data){
1962                .name = "crypto_clk_src",
1963                .parent_names = gcc_xo_gpll0_gpll0_out_main_div2,
1964                .num_parents = 3,
1965                .ops = &clk_rcg2_ops,
1966        },
1967};
1968
1969static struct freq_tbl ftbl_gp_clk_src[] = {
1970        F(19200000, P_XO, 1, 0, 0),
1971        { }
1972};
1973
1974static struct clk_rcg2 gp1_clk_src = {
1975        .cmd_rcgr = 0x08004,
1976        .freq_tbl = ftbl_gp_clk_src,
1977        .mnd_width = 8,
1978        .hid_width = 5,
1979        .parent_map = gcc_xo_gpll0_gpll6_gpll0_sleep_clk_map,
1980        .clkr.hw.init = &(struct clk_init_data){
1981                .name = "gp1_clk_src",
1982                .parent_names = gcc_xo_gpll0_gpll6_gpll0_sleep_clk,
1983                .num_parents = 5,
1984                .ops = &clk_rcg2_ops,
1985        },
1986};
1987
1988static struct clk_rcg2 gp2_clk_src = {
1989        .cmd_rcgr = 0x09004,
1990        .freq_tbl = ftbl_gp_clk_src,
1991        .mnd_width = 8,
1992        .hid_width = 5,
1993        .parent_map = gcc_xo_gpll0_gpll6_gpll0_sleep_clk_map,
1994        .clkr.hw.init = &(struct clk_init_data){
1995                .name = "gp2_clk_src",
1996                .parent_names = gcc_xo_gpll0_gpll6_gpll0_sleep_clk,
1997                .num_parents = 5,
1998                .ops = &clk_rcg2_ops,
1999        },
2000};
2001
2002static struct clk_rcg2 gp3_clk_src = {
2003        .cmd_rcgr = 0x0a004,
2004        .freq_tbl = ftbl_gp_clk_src,
2005        .mnd_width = 8,
2006        .hid_width = 5,
2007        .parent_map = gcc_xo_gpll0_gpll6_gpll0_sleep_clk_map,
2008        .clkr.hw.init = &(struct clk_init_data){
2009                .name = "gp3_clk_src",
2010                .parent_names = gcc_xo_gpll0_gpll6_gpll0_sleep_clk,
2011                .num_parents = 5,
2012                .ops = &clk_rcg2_ops,
2013        },
2014};
2015
2016static struct clk_branch gcc_blsp1_ahb_clk = {
2017        .halt_reg = 0x01008,
2018        .clkr = {
2019                .enable_reg = 0x01008,
2020                .enable_mask = BIT(0),
2021                .hw.init = &(struct clk_init_data){
2022                        .name = "gcc_blsp1_ahb_clk",
2023                        .parent_names = (const char *[]){
2024                                "pcnoc_clk_src"
2025                        },
2026                        .num_parents = 1,
2027                        .flags = CLK_SET_RATE_PARENT,
2028                        .ops = &clk_branch2_ops,
2029                },
2030        },
2031};
2032
2033static struct clk_branch gcc_blsp1_qup1_i2c_apps_clk = {
2034        .halt_reg = 0x02008,
2035        .clkr = {
2036                .enable_reg = 0x02008,
2037                .enable_mask = BIT(0),
2038                .hw.init = &(struct clk_init_data){
2039                        .name = "gcc_blsp1_qup1_i2c_apps_clk",
2040                        .parent_names = (const char *[]){
2041                                "blsp1_qup1_i2c_apps_clk_src"
2042                        },
2043                        .num_parents = 1,
2044                        .flags = CLK_SET_RATE_PARENT,
2045                        .ops = &clk_branch2_ops,
2046                },
2047        },
2048};
2049
2050static struct clk_branch gcc_blsp1_qup1_spi_apps_clk = {
2051        .halt_reg = 0x02004,
2052        .clkr = {
2053                .enable_reg = 0x02004,
2054                .enable_mask = BIT(0),
2055                .hw.init = &(struct clk_init_data){
2056                        .name = "gcc_blsp1_qup1_spi_apps_clk",
2057                        .parent_names = (const char *[]){
2058                                "blsp1_qup1_spi_apps_clk_src"
2059                        },
2060                        .num_parents = 1,
2061                        .flags = CLK_SET_RATE_PARENT,
2062                        .ops = &clk_branch2_ops,
2063                },
2064        },
2065};
2066
2067static struct clk_branch gcc_blsp1_qup2_i2c_apps_clk = {
2068        .halt_reg = 0x03010,
2069        .clkr = {
2070                .enable_reg = 0x03010,
2071                .enable_mask = BIT(0),
2072                .hw.init = &(struct clk_init_data){
2073                        .name = "gcc_blsp1_qup2_i2c_apps_clk",
2074                        .parent_names = (const char *[]){
2075                                "blsp1_qup2_i2c_apps_clk_src"
2076                        },
2077                        .num_parents = 1,
2078                        .flags = CLK_SET_RATE_PARENT,
2079                        .ops = &clk_branch2_ops,
2080                },
2081        },
2082};
2083
2084static struct clk_branch gcc_blsp1_qup2_spi_apps_clk = {
2085        .halt_reg = 0x0300c,
2086        .clkr = {
2087                .enable_reg = 0x0300c,
2088                .enable_mask = BIT(0),
2089                .hw.init = &(struct clk_init_data){
2090                        .name = "gcc_blsp1_qup2_spi_apps_clk",
2091                        .parent_names = (const char *[]){
2092                                "blsp1_qup2_spi_apps_clk_src"
2093                        },
2094                        .num_parents = 1,
2095                        .flags = CLK_SET_RATE_PARENT,
2096                        .ops = &clk_branch2_ops,
2097                },
2098        },
2099};
2100
2101static struct clk_branch gcc_blsp1_qup3_i2c_apps_clk = {
2102        .halt_reg = 0x04010,
2103        .clkr = {
2104                .enable_reg = 0x04010,
2105                .enable_mask = BIT(0),
2106                .hw.init = &(struct clk_init_data){
2107                        .name = "gcc_blsp1_qup3_i2c_apps_clk",
2108                        .parent_names = (const char *[]){
2109                                "blsp1_qup3_i2c_apps_clk_src"
2110                        },
2111                        .num_parents = 1,
2112                        .flags = CLK_SET_RATE_PARENT,
2113                        .ops = &clk_branch2_ops,
2114                },
2115        },
2116};
2117
2118static struct clk_branch gcc_blsp1_qup3_spi_apps_clk = {
2119        .halt_reg = 0x0400c,
2120        .clkr = {
2121                .enable_reg = 0x0400c,
2122                .enable_mask = BIT(0),
2123                .hw.init = &(struct clk_init_data){
2124                        .name = "gcc_blsp1_qup3_spi_apps_clk",
2125                        .parent_names = (const char *[]){
2126                                "blsp1_qup3_spi_apps_clk_src"
2127                        },
2128                        .num_parents = 1,
2129                        .flags = CLK_SET_RATE_PARENT,
2130                        .ops = &clk_branch2_ops,
2131                },
2132        },
2133};
2134
2135static struct clk_branch gcc_blsp1_qup4_i2c_apps_clk = {
2136        .halt_reg = 0x05010,
2137        .clkr = {
2138                .enable_reg = 0x05010,
2139                .enable_mask = BIT(0),
2140                .hw.init = &(struct clk_init_data){
2141                        .name = "gcc_blsp1_qup4_i2c_apps_clk",
2142                        .parent_names = (const char *[]){
2143                                "blsp1_qup4_i2c_apps_clk_src"
2144                        },
2145                        .num_parents = 1,
2146                        .flags = CLK_SET_RATE_PARENT,
2147                        .ops = &clk_branch2_ops,
2148                },
2149        },
2150};
2151
2152static struct clk_branch gcc_blsp1_qup4_spi_apps_clk = {
2153        .halt_reg = 0x0500c,
2154        .clkr = {
2155                .enable_reg = 0x0500c,
2156                .enable_mask = BIT(0),
2157                .hw.init = &(struct clk_init_data){
2158                        .name = "gcc_blsp1_qup4_spi_apps_clk",
2159                        .parent_names = (const char *[]){
2160                                "blsp1_qup4_spi_apps_clk_src"
2161                        },
2162                        .num_parents = 1,
2163                        .flags = CLK_SET_RATE_PARENT,
2164                        .ops = &clk_branch2_ops,
2165                },
2166        },
2167};
2168
2169static struct clk_branch gcc_blsp1_qup5_i2c_apps_clk = {
2170        .halt_reg = 0x06010,
2171        .clkr = {
2172                .enable_reg = 0x06010,
2173                .enable_mask = BIT(0),
2174                .hw.init = &(struct clk_init_data){
2175                        .name = "gcc_blsp1_qup5_i2c_apps_clk",
2176                        .parent_names = (const char *[]){
2177                                "blsp1_qup5_i2c_apps_clk_src"
2178                        },
2179                        .num_parents = 1,
2180                        .flags = CLK_SET_RATE_PARENT,
2181                        .ops = &clk_branch2_ops,
2182                },
2183        },
2184};
2185
2186static struct clk_branch gcc_blsp1_qup5_spi_apps_clk = {
2187        .halt_reg = 0x0600c,
2188        .clkr = {
2189                .enable_reg = 0x0600c,
2190                .enable_mask = BIT(0),
2191                .hw.init = &(struct clk_init_data){
2192                        .name = "gcc_blsp1_qup5_spi_apps_clk",
2193                        .parent_names = (const char *[]){
2194                                "blsp1_qup5_spi_apps_clk_src"
2195                        },
2196                        .num_parents = 1,
2197                        .flags = CLK_SET_RATE_PARENT,
2198                        .ops = &clk_branch2_ops,
2199                },
2200        },
2201};
2202
2203static struct clk_branch gcc_blsp1_qup6_i2c_apps_clk = {
2204        .halt_reg = 0x07010,
2205        .clkr = {
2206                .enable_reg = 0x07010,
2207                .enable_mask = BIT(0),
2208                .hw.init = &(struct clk_init_data){
2209                        .name = "gcc_blsp1_qup6_i2c_apps_clk",
2210                        .parent_names = (const char *[]){
2211                                "blsp1_qup6_i2c_apps_clk_src"
2212                        },
2213                        .num_parents = 1,
2214                        .flags = CLK_SET_RATE_PARENT,
2215                        .ops = &clk_branch2_ops,
2216                },
2217        },
2218};
2219
2220static struct clk_branch gcc_blsp1_qup6_spi_apps_clk = {
2221        .halt_reg = 0x0700c,
2222        .clkr = {
2223                .enable_reg = 0x0700c,
2224                .enable_mask = BIT(0),
2225                .hw.init = &(struct clk_init_data){
2226                        .name = "gcc_blsp1_qup6_spi_apps_clk",
2227                        .parent_names = (const char *[]){
2228                                "blsp1_qup6_spi_apps_clk_src"
2229                        },
2230                        .num_parents = 1,
2231                        .flags = CLK_SET_RATE_PARENT,
2232                        .ops = &clk_branch2_ops,
2233                },
2234        },
2235};
2236
2237static struct clk_branch gcc_blsp1_uart1_apps_clk = {
2238        .halt_reg = 0x0203c,
2239        .clkr = {
2240                .enable_reg = 0x0203c,
2241                .enable_mask = BIT(0),
2242                .hw.init = &(struct clk_init_data){
2243                        .name = "gcc_blsp1_uart1_apps_clk",
2244                        .parent_names = (const char *[]){
2245                                "blsp1_uart1_apps_clk_src"
2246                        },
2247                        .num_parents = 1,
2248                        .flags = CLK_SET_RATE_PARENT,
2249                        .ops = &clk_branch2_ops,
2250                },
2251        },
2252};
2253
2254static struct clk_branch gcc_blsp1_uart2_apps_clk = {
2255        .halt_reg = 0x0302c,
2256        .clkr = {
2257                .enable_reg = 0x0302c,
2258                .enable_mask = BIT(0),
2259                .hw.init = &(struct clk_init_data){
2260                        .name = "gcc_blsp1_uart2_apps_clk",
2261                        .parent_names = (const char *[]){
2262                                "blsp1_uart2_apps_clk_src"
2263                        },
2264                        .num_parents = 1,
2265                        .flags = CLK_SET_RATE_PARENT,
2266                        .ops = &clk_branch2_ops,
2267                },
2268        },
2269};
2270
2271static struct clk_branch gcc_blsp1_uart3_apps_clk = {
2272        .halt_reg = 0x0402c,
2273        .clkr = {
2274                .enable_reg = 0x0402c,
2275                .enable_mask = BIT(0),
2276                .hw.init = &(struct clk_init_data){
2277                        .name = "gcc_blsp1_uart3_apps_clk",
2278                        .parent_names = (const char *[]){
2279                                "blsp1_uart3_apps_clk_src"
2280                        },
2281                        .num_parents = 1,
2282                        .flags = CLK_SET_RATE_PARENT,
2283                        .ops = &clk_branch2_ops,
2284                },
2285        },
2286};
2287
2288static struct clk_branch gcc_blsp1_uart4_apps_clk = {
2289        .halt_reg = 0x0502c,
2290        .clkr = {
2291                .enable_reg = 0x0502c,
2292                .enable_mask = BIT(0),
2293                .hw.init = &(struct clk_init_data){
2294                        .name = "gcc_blsp1_uart4_apps_clk",
2295                        .parent_names = (const char *[]){
2296                                "blsp1_uart4_apps_clk_src"
2297                        },
2298                        .num_parents = 1,
2299                        .flags = CLK_SET_RATE_PARENT,
2300                        .ops = &clk_branch2_ops,
2301                },
2302        },
2303};
2304
2305static struct clk_branch gcc_blsp1_uart5_apps_clk = {
2306        .halt_reg = 0x0602c,
2307        .clkr = {
2308                .enable_reg = 0x0602c,
2309                .enable_mask = BIT(0),
2310                .hw.init = &(struct clk_init_data){
2311                        .name = "gcc_blsp1_uart5_apps_clk",
2312                        .parent_names = (const char *[]){
2313                                "blsp1_uart5_apps_clk_src"
2314                        },
2315                        .num_parents = 1,
2316                        .flags = CLK_SET_RATE_PARENT,
2317                        .ops = &clk_branch2_ops,
2318                },
2319        },
2320};
2321
2322static struct clk_branch gcc_blsp1_uart6_apps_clk = {
2323        .halt_reg = 0x0702c,
2324        .clkr = {
2325                .enable_reg = 0x0702c,
2326                .enable_mask = BIT(0),
2327                .hw.init = &(struct clk_init_data){
2328                        .name = "gcc_blsp1_uart6_apps_clk",
2329                        .parent_names = (const char *[]){
2330                                "blsp1_uart6_apps_clk_src"
2331                        },
2332                        .num_parents = 1,
2333                        .flags = CLK_SET_RATE_PARENT,
2334                        .ops = &clk_branch2_ops,
2335                },
2336        },
2337};
2338
2339static struct clk_branch gcc_prng_ahb_clk = {
2340        .halt_reg = 0x13004,
2341        .halt_check = BRANCH_HALT_VOTED,
2342        .clkr = {
2343                .enable_reg = 0x0b004,
2344                .enable_mask = BIT(8),
2345                .hw.init = &(struct clk_init_data){
2346                        .name = "gcc_prng_ahb_clk",
2347                        .parent_names = (const char *[]){
2348                                "pcnoc_clk_src"
2349                        },
2350                        .num_parents = 1,
2351                        .flags = CLK_SET_RATE_PARENT,
2352                        .ops = &clk_branch2_ops,
2353                },
2354        },
2355};
2356
2357static struct clk_branch gcc_qpic_ahb_clk = {
2358        .halt_reg = 0x57024,
2359        .clkr = {
2360                .enable_reg = 0x57024,
2361                .enable_mask = BIT(0),
2362                .hw.init = &(struct clk_init_data){
2363                        .name = "gcc_qpic_ahb_clk",
2364                        .parent_names = (const char *[]){
2365                                "pcnoc_clk_src"
2366                        },
2367                        .num_parents = 1,
2368                        .flags = CLK_SET_RATE_PARENT,
2369                        .ops = &clk_branch2_ops,
2370                },
2371        },
2372};
2373
2374static struct clk_branch gcc_qpic_clk = {
2375        .halt_reg = 0x57020,
2376        .clkr = {
2377                .enable_reg = 0x57020,
2378                .enable_mask = BIT(0),
2379                .hw.init = &(struct clk_init_data){
2380                        .name = "gcc_qpic_clk",
2381                        .parent_names = (const char *[]){
2382                                "pcnoc_clk_src"
2383                        },
2384                        .num_parents = 1,
2385                        .flags = CLK_SET_RATE_PARENT,
2386                        .ops = &clk_branch2_ops,
2387                },
2388        },
2389};
2390
2391static struct clk_branch gcc_pcie0_ahb_clk = {
2392        .halt_reg = 0x75010,
2393        .clkr = {
2394                .enable_reg = 0x75010,
2395                .enable_mask = BIT(0),
2396                .hw.init = &(struct clk_init_data){
2397                        .name = "gcc_pcie0_ahb_clk",
2398                        .parent_names = (const char *[]){
2399                                "pcnoc_clk_src"
2400                        },
2401                        .num_parents = 1,
2402                        .flags = CLK_SET_RATE_PARENT,
2403                        .ops = &clk_branch2_ops,
2404                },
2405        },
2406};
2407
2408static struct clk_branch gcc_pcie0_aux_clk = {
2409        .halt_reg = 0x75014,
2410        .clkr = {
2411                .enable_reg = 0x75014,
2412                .enable_mask = BIT(0),
2413                .hw.init = &(struct clk_init_data){
2414                        .name = "gcc_pcie0_aux_clk",
2415                        .parent_names = (const char *[]){
2416                                "pcie0_aux_clk_src"
2417                        },
2418                        .num_parents = 1,
2419                        .flags = CLK_SET_RATE_PARENT,
2420                        .ops = &clk_branch2_ops,
2421                },
2422        },
2423};
2424
2425static struct clk_branch gcc_pcie0_axi_m_clk = {
2426        .halt_reg = 0x75008,
2427        .clkr = {
2428                .enable_reg = 0x75008,
2429                .enable_mask = BIT(0),
2430                .hw.init = &(struct clk_init_data){
2431                        .name = "gcc_pcie0_axi_m_clk",
2432                        .parent_names = (const char *[]){
2433                                "pcie0_axi_clk_src"
2434                        },
2435                        .num_parents = 1,
2436                        .flags = CLK_SET_RATE_PARENT,
2437                        .ops = &clk_branch2_ops,
2438                },
2439        },
2440};
2441
2442static struct clk_branch gcc_pcie0_axi_s_clk = {
2443        .halt_reg = 0x7500c,
2444        .clkr = {
2445                .enable_reg = 0x7500c,
2446                .enable_mask = BIT(0),
2447                .hw.init = &(struct clk_init_data){
2448                        .name = "gcc_pcie0_axi_s_clk",
2449                        .parent_names = (const char *[]){
2450                                "pcie0_axi_clk_src"
2451                        },
2452                        .num_parents = 1,
2453                        .flags = CLK_SET_RATE_PARENT,
2454                        .ops = &clk_branch2_ops,
2455                },
2456        },
2457};
2458
2459static struct clk_branch gcc_pcie0_pipe_clk = {
2460        .halt_reg = 0x75018,
2461        .halt_check = BRANCH_HALT_DELAY,
2462        .clkr = {
2463                .enable_reg = 0x75018,
2464                .enable_mask = BIT(0),
2465                .hw.init = &(struct clk_init_data){
2466                        .name = "gcc_pcie0_pipe_clk",
2467                        .parent_names = (const char *[]){
2468                                "pcie0_pipe_clk_src"
2469                        },
2470                        .num_parents = 1,
2471                        .flags = CLK_SET_RATE_PARENT,
2472                        .ops = &clk_branch2_ops,
2473                },
2474        },
2475};
2476
2477static struct clk_branch gcc_sys_noc_pcie0_axi_clk = {
2478        .halt_reg = 0x26048,
2479        .clkr = {
2480                .enable_reg = 0x26048,
2481                .enable_mask = BIT(0),
2482                .hw.init = &(struct clk_init_data){
2483                        .name = "gcc_sys_noc_pcie0_axi_clk",
2484                        .parent_names = (const char *[]){
2485                                "pcie0_axi_clk_src"
2486                        },
2487                        .num_parents = 1,
2488                        .flags = CLK_SET_RATE_PARENT,
2489                        .ops = &clk_branch2_ops,
2490                },
2491        },
2492};
2493
2494static struct clk_branch gcc_pcie1_ahb_clk = {
2495        .halt_reg = 0x76010,
2496        .clkr = {
2497                .enable_reg = 0x76010,
2498                .enable_mask = BIT(0),
2499                .hw.init = &(struct clk_init_data){
2500                        .name = "gcc_pcie1_ahb_clk",
2501                        .parent_names = (const char *[]){
2502                                "pcnoc_clk_src"
2503                        },
2504                        .num_parents = 1,
2505                        .flags = CLK_SET_RATE_PARENT,
2506                        .ops = &clk_branch2_ops,
2507                },
2508        },
2509};
2510
2511static struct clk_branch gcc_pcie1_aux_clk = {
2512        .halt_reg = 0x76014,
2513        .clkr = {
2514                .enable_reg = 0x76014,
2515                .enable_mask = BIT(0),
2516                .hw.init = &(struct clk_init_data){
2517                        .name = "gcc_pcie1_aux_clk",
2518                        .parent_names = (const char *[]){
2519                                "pcie1_aux_clk_src"
2520                        },
2521                        .num_parents = 1,
2522                        .flags = CLK_SET_RATE_PARENT,
2523                        .ops = &clk_branch2_ops,
2524                },
2525        },
2526};
2527
2528static struct clk_branch gcc_pcie1_axi_m_clk = {
2529        .halt_reg = 0x76008,
2530        .clkr = {
2531                .enable_reg = 0x76008,
2532                .enable_mask = BIT(0),
2533                .hw.init = &(struct clk_init_data){
2534                        .name = "gcc_pcie1_axi_m_clk",
2535                        .parent_names = (const char *[]){
2536                                "pcie1_axi_clk_src"
2537                        },
2538                        .num_parents = 1,
2539                        .flags = CLK_SET_RATE_PARENT,
2540                        .ops = &clk_branch2_ops,
2541                },
2542        },
2543};
2544
2545static struct clk_branch gcc_pcie1_axi_s_clk = {
2546        .halt_reg = 0x7600c,
2547        .clkr = {
2548                .enable_reg = 0x7600c,
2549                .enable_mask = BIT(0),
2550                .hw.init = &(struct clk_init_data){
2551                        .name = "gcc_pcie1_axi_s_clk",
2552                        .parent_names = (const char *[]){
2553                                "pcie1_axi_clk_src"
2554                        },
2555                        .num_parents = 1,
2556                        .flags = CLK_SET_RATE_PARENT,
2557                        .ops = &clk_branch2_ops,
2558                },
2559        },
2560};
2561
2562static struct clk_branch gcc_pcie1_pipe_clk = {
2563        .halt_reg = 0x76018,
2564        .halt_check = BRANCH_HALT_DELAY,
2565        .clkr = {
2566                .enable_reg = 0x76018,
2567                .enable_mask = BIT(0),
2568                .hw.init = &(struct clk_init_data){
2569                        .name = "gcc_pcie1_pipe_clk",
2570                        .parent_names = (const char *[]){
2571                                "pcie1_pipe_clk_src"
2572                        },
2573                        .num_parents = 1,
2574                        .flags = CLK_SET_RATE_PARENT,
2575                        .ops = &clk_branch2_ops,
2576                },
2577        },
2578};
2579
2580static struct clk_branch gcc_sys_noc_pcie1_axi_clk = {
2581        .halt_reg = 0x2604c,
2582        .clkr = {
2583                .enable_reg = 0x2604c,
2584                .enable_mask = BIT(0),
2585                .hw.init = &(struct clk_init_data){
2586                        .name = "gcc_sys_noc_pcie1_axi_clk",
2587                        .parent_names = (const char *[]){
2588                                "pcie1_axi_clk_src"
2589                        },
2590                        .num_parents = 1,
2591                        .flags = CLK_SET_RATE_PARENT,
2592                        .ops = &clk_branch2_ops,
2593                },
2594        },
2595};
2596
2597static struct clk_branch gcc_usb0_aux_clk = {
2598        .halt_reg = 0x3e044,
2599        .clkr = {
2600                .enable_reg = 0x3e044,
2601                .enable_mask = BIT(0),
2602                .hw.init = &(struct clk_init_data){
2603                        .name = "gcc_usb0_aux_clk",
2604                        .parent_names = (const char *[]){
2605                                "usb0_aux_clk_src"
2606                        },
2607                        .num_parents = 1,
2608                        .flags = CLK_SET_RATE_PARENT,
2609                        .ops = &clk_branch2_ops,
2610                },
2611        },
2612};
2613
2614static struct clk_branch gcc_sys_noc_usb0_axi_clk = {
2615        .halt_reg = 0x26040,
2616        .clkr = {
2617                .enable_reg = 0x26040,
2618                .enable_mask = BIT(0),
2619                .hw.init = &(struct clk_init_data){
2620                        .name = "gcc_sys_noc_usb0_axi_clk",
2621                        .parent_names = (const char *[]){
2622                                "usb0_master_clk_src"
2623                        },
2624                        .num_parents = 1,
2625                        .flags = CLK_SET_RATE_PARENT,
2626                        .ops = &clk_branch2_ops,
2627                },
2628        },
2629};
2630
2631static struct clk_branch gcc_usb0_master_clk = {
2632        .halt_reg = 0x3e000,
2633        .clkr = {
2634                .enable_reg = 0x3e000,
2635                .enable_mask = BIT(0),
2636                .hw.init = &(struct clk_init_data){
2637                        .name = "gcc_usb0_master_clk",
2638                        .parent_names = (const char *[]){
2639                                "usb0_master_clk_src"
2640                        },
2641                        .num_parents = 1,
2642                        .flags = CLK_SET_RATE_PARENT,
2643                        .ops = &clk_branch2_ops,
2644                },
2645        },
2646};
2647
2648static struct clk_branch gcc_usb0_mock_utmi_clk = {
2649        .halt_reg = 0x3e008,
2650        .clkr = {
2651                .enable_reg = 0x3e008,
2652                .enable_mask = BIT(0),
2653                .hw.init = &(struct clk_init_data){
2654                        .name = "gcc_usb0_mock_utmi_clk",
2655                        .parent_names = (const char *[]){
2656                                "usb0_mock_utmi_clk_src"
2657                        },
2658                        .num_parents = 1,
2659                        .flags = CLK_SET_RATE_PARENT,
2660                        .ops = &clk_branch2_ops,
2661                },
2662        },
2663};
2664
2665static struct clk_branch gcc_usb0_phy_cfg_ahb_clk = {
2666        .halt_reg = 0x3e080,
2667        .clkr = {
2668                .enable_reg = 0x3e080,
2669                .enable_mask = BIT(0),
2670                .hw.init = &(struct clk_init_data){
2671                        .name = "gcc_usb0_phy_cfg_ahb_clk",
2672                        .parent_names = (const char *[]){
2673                                "pcnoc_clk_src"
2674                        },
2675                        .num_parents = 1,
2676                        .flags = CLK_SET_RATE_PARENT,
2677                        .ops = &clk_branch2_ops,
2678                },
2679        },
2680};
2681
2682static struct clk_branch gcc_usb0_pipe_clk = {
2683        .halt_reg = 0x3e040,
2684        .halt_check = BRANCH_HALT_DELAY,
2685        .clkr = {
2686                .enable_reg = 0x3e040,
2687                .enable_mask = BIT(0),
2688                .hw.init = &(struct clk_init_data){
2689                        .name = "gcc_usb0_pipe_clk",
2690                        .parent_names = (const char *[]){
2691                                "usb0_pipe_clk_src"
2692                        },
2693                        .num_parents = 1,
2694                        .flags = CLK_SET_RATE_PARENT,
2695                        .ops = &clk_branch2_ops,
2696                },
2697        },
2698};
2699
2700static struct clk_branch gcc_usb0_sleep_clk = {
2701        .halt_reg = 0x3e004,
2702        .clkr = {
2703                .enable_reg = 0x3e004,
2704                .enable_mask = BIT(0),
2705                .hw.init = &(struct clk_init_data){
2706                        .name = "gcc_usb0_sleep_clk",
2707                        .parent_names = (const char *[]){
2708                                "gcc_sleep_clk_src"
2709                        },
2710                        .num_parents = 1,
2711                        .flags = CLK_SET_RATE_PARENT,
2712                        .ops = &clk_branch2_ops,
2713                },
2714        },
2715};
2716
2717static struct clk_branch gcc_usb1_aux_clk = {
2718        .halt_reg = 0x3f044,
2719        .clkr = {
2720                .enable_reg = 0x3f044,
2721                .enable_mask = BIT(0),
2722                .hw.init = &(struct clk_init_data){
2723                        .name = "gcc_usb1_aux_clk",
2724                        .parent_names = (const char *[]){
2725                                "usb1_aux_clk_src"
2726                        },
2727                        .num_parents = 1,
2728                        .flags = CLK_SET_RATE_PARENT,
2729                        .ops = &clk_branch2_ops,
2730                },
2731        },
2732};
2733
2734static struct clk_branch gcc_sys_noc_usb1_axi_clk = {
2735        .halt_reg = 0x26044,
2736        .clkr = {
2737                .enable_reg = 0x26044,
2738                .enable_mask = BIT(0),
2739                .hw.init = &(struct clk_init_data){
2740                        .name = "gcc_sys_noc_usb1_axi_clk",
2741                        .parent_names = (const char *[]){
2742                                "usb1_master_clk_src"
2743                        },
2744                        .num_parents = 1,
2745                        .flags = CLK_SET_RATE_PARENT,
2746                        .ops = &clk_branch2_ops,
2747                },
2748        },
2749};
2750
2751static struct clk_branch gcc_usb1_master_clk = {
2752        .halt_reg = 0x3f000,
2753        .clkr = {
2754                .enable_reg = 0x3f000,
2755                .enable_mask = BIT(0),
2756                .hw.init = &(struct clk_init_data){
2757                        .name = "gcc_usb1_master_clk",
2758                        .parent_names = (const char *[]){
2759                                "usb1_master_clk_src"
2760                        },
2761                        .num_parents = 1,
2762                        .flags = CLK_SET_RATE_PARENT,
2763                        .ops = &clk_branch2_ops,
2764                },
2765        },
2766};
2767
2768static struct clk_branch gcc_usb1_mock_utmi_clk = {
2769        .halt_reg = 0x3f008,
2770        .clkr = {
2771                .enable_reg = 0x3f008,
2772                .enable_mask = BIT(0),
2773                .hw.init = &(struct clk_init_data){
2774                        .name = "gcc_usb1_mock_utmi_clk",
2775                        .parent_names = (const char *[]){
2776                                "usb1_mock_utmi_clk_src"
2777                        },
2778                        .num_parents = 1,
2779                        .flags = CLK_SET_RATE_PARENT,
2780                        .ops = &clk_branch2_ops,
2781                },
2782        },
2783};
2784
2785static struct clk_branch gcc_usb1_phy_cfg_ahb_clk = {
2786        .halt_reg = 0x3f080,
2787        .clkr = {
2788                .enable_reg = 0x3f080,
2789                .enable_mask = BIT(0),
2790                .hw.init = &(struct clk_init_data){
2791                        .name = "gcc_usb1_phy_cfg_ahb_clk",
2792                        .parent_names = (const char *[]){
2793                                "pcnoc_clk_src"
2794                        },
2795                        .num_parents = 1,
2796                        .flags = CLK_SET_RATE_PARENT,
2797                        .ops = &clk_branch2_ops,
2798                },
2799        },
2800};
2801
2802static struct clk_branch gcc_usb1_pipe_clk = {
2803        .halt_reg = 0x3f040,
2804        .halt_check = BRANCH_HALT_DELAY,
2805        .clkr = {
2806                .enable_reg = 0x3f040,
2807                .enable_mask = BIT(0),
2808                .hw.init = &(struct clk_init_data){
2809                        .name = "gcc_usb1_pipe_clk",
2810                        .parent_names = (const char *[]){
2811                                "usb1_pipe_clk_src"
2812                        },
2813                        .num_parents = 1,
2814                        .flags = CLK_SET_RATE_PARENT,
2815                        .ops = &clk_branch2_ops,
2816                },
2817        },
2818};
2819
2820static struct clk_branch gcc_usb1_sleep_clk = {
2821        .halt_reg = 0x3f004,
2822        .clkr = {
2823                .enable_reg = 0x3f004,
2824                .enable_mask = BIT(0),
2825                .hw.init = &(struct clk_init_data){
2826                        .name = "gcc_usb1_sleep_clk",
2827                        .parent_names = (const char *[]){
2828                                "gcc_sleep_clk_src"
2829                        },
2830                        .num_parents = 1,
2831                        .flags = CLK_SET_RATE_PARENT,
2832                        .ops = &clk_branch2_ops,
2833                },
2834        },
2835};
2836
2837static struct clk_branch gcc_sdcc1_ahb_clk = {
2838        .halt_reg = 0x4201c,
2839        .clkr = {
2840                .enable_reg = 0x4201c,
2841                .enable_mask = BIT(0),
2842                .hw.init = &(struct clk_init_data){
2843                        .name = "gcc_sdcc1_ahb_clk",
2844                        .parent_names = (const char *[]){
2845                                "pcnoc_clk_src"
2846                        },
2847                        .num_parents = 1,
2848                        .flags = CLK_SET_RATE_PARENT,
2849                        .ops = &clk_branch2_ops,
2850                },
2851        },
2852};
2853
2854static struct clk_branch gcc_sdcc1_apps_clk = {
2855        .halt_reg = 0x42018,
2856        .clkr = {
2857                .enable_reg = 0x42018,
2858                .enable_mask = BIT(0),
2859                .hw.init = &(struct clk_init_data){
2860                        .name = "gcc_sdcc1_apps_clk",
2861                        .parent_names = (const char *[]){
2862                                "sdcc1_apps_clk_src"
2863                        },
2864                        .num_parents = 1,
2865                        .flags = CLK_SET_RATE_PARENT,
2866                        .ops = &clk_branch2_ops,
2867                },
2868        },
2869};
2870
2871static struct clk_branch gcc_sdcc1_ice_core_clk = {
2872        .halt_reg = 0x5d014,
2873        .clkr = {
2874                .enable_reg = 0x5d014,
2875                .enable_mask = BIT(0),
2876                .hw.init = &(struct clk_init_data){
2877                        .name = "gcc_sdcc1_ice_core_clk",
2878                        .parent_names = (const char *[]){
2879                                "sdcc1_ice_core_clk_src"
2880                        },
2881                        .num_parents = 1,
2882                        .flags = CLK_SET_RATE_PARENT,
2883                        .ops = &clk_branch2_ops,
2884                },
2885        },
2886};
2887
2888static struct clk_branch gcc_sdcc2_ahb_clk = {
2889        .halt_reg = 0x4301c,
2890        .clkr = {
2891                .enable_reg = 0x4301c,
2892                .enable_mask = BIT(0),
2893                .hw.init = &(struct clk_init_data){
2894                        .name = "gcc_sdcc2_ahb_clk",
2895                        .parent_names = (const char *[]){
2896                                "pcnoc_clk_src"
2897                        },
2898                        .num_parents = 1,
2899                        .flags = CLK_SET_RATE_PARENT,
2900                        .ops = &clk_branch2_ops,
2901                },
2902        },
2903};
2904
2905static struct clk_branch gcc_sdcc2_apps_clk = {
2906        .halt_reg = 0x43018,
2907        .clkr = {
2908                .enable_reg = 0x43018,
2909                .enable_mask = BIT(0),
2910                .hw.init = &(struct clk_init_data){
2911                        .name = "gcc_sdcc2_apps_clk",
2912                        .parent_names = (const char *[]){
2913                                "sdcc2_apps_clk_src"
2914                        },
2915                        .num_parents = 1,
2916                        .flags = CLK_SET_RATE_PARENT,
2917                        .ops = &clk_branch2_ops,
2918                },
2919        },
2920};
2921
2922static struct clk_branch gcc_mem_noc_nss_axi_clk = {
2923        .halt_reg = 0x1d03c,
2924        .clkr = {
2925                .enable_reg = 0x1d03c,
2926                .enable_mask = BIT(0),
2927                .hw.init = &(struct clk_init_data){
2928                        .name = "gcc_mem_noc_nss_axi_clk",
2929                        .parent_names = (const char *[]){
2930                                "nss_noc_clk_src"
2931                        },
2932                        .num_parents = 1,
2933                        .flags = CLK_SET_RATE_PARENT,
2934                        .ops = &clk_branch2_ops,
2935                },
2936        },
2937};
2938
2939static struct clk_branch gcc_nss_ce_apb_clk = {
2940        .halt_reg = 0x68174,
2941        .clkr = {
2942                .enable_reg = 0x68174,
2943                .enable_mask = BIT(0),
2944                .hw.init = &(struct clk_init_data){
2945                        .name = "gcc_nss_ce_apb_clk",
2946                        .parent_names = (const char *[]){
2947                                "nss_ce_clk_src"
2948                        },
2949                        .num_parents = 1,
2950                        .flags = CLK_SET_RATE_PARENT,
2951                        .ops = &clk_branch2_ops,
2952                },
2953        },
2954};
2955
2956static struct clk_branch gcc_nss_ce_axi_clk = {
2957        .halt_reg = 0x68170,
2958        .clkr = {
2959                .enable_reg = 0x68170,
2960                .enable_mask = BIT(0),
2961                .hw.init = &(struct clk_init_data){
2962                        .name = "gcc_nss_ce_axi_clk",
2963                        .parent_names = (const char *[]){
2964                                "nss_ce_clk_src"
2965                        },
2966                        .num_parents = 1,
2967                        .flags = CLK_SET_RATE_PARENT,
2968                        .ops = &clk_branch2_ops,
2969                },
2970        },
2971};
2972
2973static struct clk_branch gcc_nss_cfg_clk = {
2974        .halt_reg = 0x68160,
2975        .clkr = {
2976                .enable_reg = 0x68160,
2977                .enable_mask = BIT(0),
2978                .hw.init = &(struct clk_init_data){
2979                        .name = "gcc_nss_cfg_clk",
2980                        .parent_names = (const char *[]){
2981                                "pcnoc_clk_src"
2982                        },
2983                        .num_parents = 1,
2984                        .flags = CLK_SET_RATE_PARENT,
2985                        .ops = &clk_branch2_ops,
2986                },
2987        },
2988};
2989
2990static struct clk_branch gcc_nss_crypto_clk = {
2991        .halt_reg = 0x68164,
2992        .clkr = {
2993                .enable_reg = 0x68164,
2994                .enable_mask = BIT(0),
2995                .hw.init = &(struct clk_init_data){
2996                        .name = "gcc_nss_crypto_clk",
2997                        .parent_names = (const char *[]){
2998                                "nss_crypto_clk_src"
2999                        },
3000                        .num_parents = 1,
3001                        .flags = CLK_SET_RATE_PARENT,
3002                        .ops = &clk_branch2_ops,
3003                },
3004        },
3005};
3006
3007static struct clk_branch gcc_nss_csr_clk = {
3008        .halt_reg = 0x68318,
3009        .clkr = {
3010                .enable_reg = 0x68318,
3011                .enable_mask = BIT(0),
3012                .hw.init = &(struct clk_init_data){
3013                        .name = "gcc_nss_csr_clk",
3014                        .parent_names = (const char *[]){
3015                                "nss_ce_clk_src"
3016                        },
3017                        .num_parents = 1,
3018                        .flags = CLK_SET_RATE_PARENT,
3019                        .ops = &clk_branch2_ops,
3020                },
3021        },
3022};
3023
3024static struct clk_branch gcc_nss_edma_cfg_clk = {
3025        .halt_reg = 0x6819c,
3026        .clkr = {
3027                .enable_reg = 0x6819c,
3028                .enable_mask = BIT(0),
3029                .hw.init = &(struct clk_init_data){
3030                        .name = "gcc_nss_edma_cfg_clk",
3031                        .parent_names = (const char *[]){
3032                                "nss_ppe_clk_src"
3033                        },
3034                        .num_parents = 1,
3035                        .flags = CLK_SET_RATE_PARENT,
3036                        .ops = &clk_branch2_ops,
3037                },
3038        },
3039};
3040
3041static struct clk_branch gcc_nss_edma_clk = {
3042        .halt_reg = 0x68198,
3043        .clkr = {
3044                .enable_reg = 0x68198,
3045                .enable_mask = BIT(0),
3046                .hw.init = &(struct clk_init_data){
3047                        .name = "gcc_nss_edma_clk",
3048                        .parent_names = (const char *[]){
3049                                "nss_ppe_clk_src"
3050                        },
3051                        .num_parents = 1,
3052                        .flags = CLK_SET_RATE_PARENT,
3053                        .ops = &clk_branch2_ops,
3054                },
3055        },
3056};
3057
3058static struct clk_branch gcc_nss_imem_clk = {
3059        .halt_reg = 0x68178,
3060        .clkr = {
3061                .enable_reg = 0x68178,
3062                .enable_mask = BIT(0),
3063                .hw.init = &(struct clk_init_data){
3064                        .name = "gcc_nss_imem_clk",
3065                        .parent_names = (const char *[]){
3066                                "nss_imem_clk_src"
3067                        },
3068                        .num_parents = 1,
3069                        .flags = CLK_SET_RATE_PARENT,
3070                        .ops = &clk_branch2_ops,
3071                },
3072        },
3073};
3074
3075static struct clk_branch gcc_nss_noc_clk = {
3076        .halt_reg = 0x68168,
3077        .clkr = {
3078                .enable_reg = 0x68168,
3079                .enable_mask = BIT(0),
3080                .hw.init = &(struct clk_init_data){
3081                        .name = "gcc_nss_noc_clk",
3082                        .parent_names = (const char *[]){
3083                                "nss_noc_clk_src"
3084                        },
3085                        .num_parents = 1,
3086                        .flags = CLK_SET_RATE_PARENT,
3087                        .ops = &clk_branch2_ops,
3088                },
3089        },
3090};
3091
3092static struct clk_branch gcc_nss_ppe_btq_clk = {
3093        .halt_reg = 0x6833c,
3094        .clkr = {
3095                .enable_reg = 0x6833c,
3096                .enable_mask = BIT(0),
3097                .hw.init = &(struct clk_init_data){
3098                        .name = "gcc_nss_ppe_btq_clk",
3099                        .parent_names = (const char *[]){
3100                                "nss_ppe_clk_src"
3101                        },
3102                        .num_parents = 1,
3103                        .flags = CLK_SET_RATE_PARENT,
3104                        .ops = &clk_branch2_ops,
3105                },
3106        },
3107};
3108
3109static struct clk_branch gcc_nss_ppe_cfg_clk = {
3110        .halt_reg = 0x68194,
3111        .clkr = {
3112                .enable_reg = 0x68194,
3113                .enable_mask = BIT(0),
3114                .hw.init = &(struct clk_init_data){
3115                        .name = "gcc_nss_ppe_cfg_clk",
3116                        .parent_names = (const char *[]){
3117                                "nss_ppe_clk_src"
3118                        },
3119                        .num_parents = 1,
3120                        .flags = CLK_SET_RATE_PARENT,
3121                        .ops = &clk_branch2_ops,
3122                },
3123        },
3124};
3125
3126static struct clk_branch gcc_nss_ppe_clk = {
3127        .halt_reg = 0x68190,
3128        .clkr = {
3129                .enable_reg = 0x68190,
3130                .enable_mask = BIT(0),
3131                .hw.init = &(struct clk_init_data){
3132                        .name = "gcc_nss_ppe_clk",
3133                        .parent_names = (const char *[]){
3134                                "nss_ppe_clk_src"
3135                        },
3136                        .num_parents = 1,
3137                        .flags = CLK_SET_RATE_PARENT,
3138                        .ops = &clk_branch2_ops,
3139                },
3140        },
3141};
3142
3143static struct clk_branch gcc_nss_ppe_ipe_clk = {
3144        .halt_reg = 0x68338,
3145        .clkr = {
3146                .enable_reg = 0x68338,
3147                .enable_mask = BIT(0),
3148                .hw.init = &(struct clk_init_data){
3149                        .name = "gcc_nss_ppe_ipe_clk",
3150                        .parent_names = (const char *[]){
3151                                "nss_ppe_clk_src"
3152                        },
3153                        .num_parents = 1,
3154                        .flags = CLK_SET_RATE_PARENT,
3155                        .ops = &clk_branch2_ops,
3156                },
3157        },
3158};
3159
3160static struct clk_branch gcc_nss_ptp_ref_clk = {
3161        .halt_reg = 0x6816c,
3162        .clkr = {
3163                .enable_reg = 0x6816c,
3164                .enable_mask = BIT(0),
3165                .hw.init = &(struct clk_init_data){
3166                        .name = "gcc_nss_ptp_ref_clk",
3167                        .parent_names = (const char *[]){
3168                                "nss_ppe_cdiv_clk_src"
3169                        },
3170                        .num_parents = 1,
3171                        .flags = CLK_SET_RATE_PARENT,
3172                        .ops = &clk_branch2_ops,
3173                },
3174        },
3175};
3176
3177static struct clk_branch gcc_nssnoc_ce_apb_clk = {
3178        .halt_reg = 0x6830c,
3179        .clkr = {
3180                .enable_reg = 0x6830c,
3181                .enable_mask = BIT(0),
3182                .hw.init = &(struct clk_init_data){
3183                        .name = "gcc_nssnoc_ce_apb_clk",
3184                        .parent_names = (const char *[]){
3185                                "nss_ce_clk_src"
3186                        },
3187                        .num_parents = 1,
3188                        .flags = CLK_SET_RATE_PARENT,
3189                        .ops = &clk_branch2_ops,
3190                },
3191        },
3192};
3193
3194static struct clk_branch gcc_nssnoc_ce_axi_clk = {
3195        .halt_reg = 0x68308,
3196        .clkr = {
3197                .enable_reg = 0x68308,
3198                .enable_mask = BIT(0),
3199                .hw.init = &(struct clk_init_data){
3200                        .name = "gcc_nssnoc_ce_axi_clk",
3201                        .parent_names = (const char *[]){
3202                                "nss_ce_clk_src"
3203                        },
3204                        .num_parents = 1,
3205                        .flags = CLK_SET_RATE_PARENT,
3206                        .ops = &clk_branch2_ops,
3207                },
3208        },
3209};
3210
3211static struct clk_branch gcc_nssnoc_crypto_clk = {
3212        .halt_reg = 0x68314,
3213        .clkr = {
3214                .enable_reg = 0x68314,
3215                .enable_mask = BIT(0),
3216                .hw.init = &(struct clk_init_data){
3217                        .name = "gcc_nssnoc_crypto_clk",
3218                        .parent_names = (const char *[]){
3219                                "nss_crypto_clk_src"
3220                        },
3221                        .num_parents = 1,
3222                        .flags = CLK_SET_RATE_PARENT,
3223                        .ops = &clk_branch2_ops,
3224                },
3225        },
3226};
3227
3228static struct clk_branch gcc_nssnoc_ppe_cfg_clk = {
3229        .halt_reg = 0x68304,
3230        .clkr = {
3231                .enable_reg = 0x68304,
3232                .enable_mask = BIT(0),
3233                .hw.init = &(struct clk_init_data){
3234                        .name = "gcc_nssnoc_ppe_cfg_clk",
3235                        .parent_names = (const char *[]){
3236                                "nss_ppe_clk_src"
3237                        },
3238                        .num_parents = 1,
3239                        .flags = CLK_SET_RATE_PARENT,
3240                        .ops = &clk_branch2_ops,
3241                },
3242        },
3243};
3244
3245static struct clk_branch gcc_nssnoc_ppe_clk = {
3246        .halt_reg = 0x68300,
3247        .clkr = {
3248                .enable_reg = 0x68300,
3249                .enable_mask = BIT(0),
3250                .hw.init = &(struct clk_init_data){
3251                        .name = "gcc_nssnoc_ppe_clk",
3252                        .parent_names = (const char *[]){
3253                                "nss_ppe_clk_src"
3254                        },
3255                        .num_parents = 1,
3256                        .flags = CLK_SET_RATE_PARENT,
3257                        .ops = &clk_branch2_ops,
3258                },
3259        },
3260};
3261
3262static struct clk_branch gcc_nssnoc_qosgen_ref_clk = {
3263        .halt_reg = 0x68180,
3264        .clkr = {
3265                .enable_reg = 0x68180,
3266                .enable_mask = BIT(0),
3267                .hw.init = &(struct clk_init_data){
3268                        .name = "gcc_nssnoc_qosgen_ref_clk",
3269                        .parent_names = (const char *[]){
3270                                "gcc_xo_clk_src"
3271                        },
3272                        .num_parents = 1,
3273                        .flags = CLK_SET_RATE_PARENT,
3274                        .ops = &clk_branch2_ops,
3275                },
3276        },
3277};
3278
3279static struct clk_branch gcc_nssnoc_snoc_clk = {
3280        .halt_reg = 0x68188,
3281        .clkr = {
3282                .enable_reg = 0x68188,
3283                .enable_mask = BIT(0),
3284                .hw.init = &(struct clk_init_data){
3285                        .name = "gcc_nssnoc_snoc_clk",
3286                        .parent_names = (const char *[]){
3287                                "system_noc_clk_src"
3288                        },
3289                        .num_parents = 1,
3290                        .flags = CLK_SET_RATE_PARENT,
3291                        .ops = &clk_branch2_ops,
3292                },
3293        },
3294};
3295
3296static struct clk_branch gcc_nssnoc_timeout_ref_clk = {
3297        .halt_reg = 0x68184,
3298        .clkr = {
3299                .enable_reg = 0x68184,
3300                .enable_mask = BIT(0),
3301                .hw.init = &(struct clk_init_data){
3302                        .name = "gcc_nssnoc_timeout_ref_clk",
3303                        .parent_names = (const char *[]){
3304                                "gcc_xo_div4_clk_src"
3305                        },
3306                        .num_parents = 1,
3307                        .flags = CLK_SET_RATE_PARENT,
3308                        .ops = &clk_branch2_ops,
3309                },
3310        },
3311};
3312
3313static struct clk_branch gcc_nssnoc_ubi0_ahb_clk = {
3314        .halt_reg = 0x68270,
3315        .clkr = {
3316                .enable_reg = 0x68270,
3317                .enable_mask = BIT(0),
3318                .hw.init = &(struct clk_init_data){
3319                        .name = "gcc_nssnoc_ubi0_ahb_clk",
3320                        .parent_names = (const char *[]){
3321                                "nss_ce_clk_src"
3322                        },
3323                        .num_parents = 1,
3324                        .flags = CLK_SET_RATE_PARENT,
3325                        .ops = &clk_branch2_ops,
3326                },
3327        },
3328};
3329
3330static struct clk_branch gcc_nssnoc_ubi1_ahb_clk = {
3331        .halt_reg = 0x68274,
3332        .clkr = {
3333                .enable_reg = 0x68274,
3334                .enable_mask = BIT(0),
3335                .hw.init = &(struct clk_init_data){
3336                        .name = "gcc_nssnoc_ubi1_ahb_clk",
3337                        .parent_names = (const char *[]){
3338                                "nss_ce_clk_src"
3339                        },
3340                        .num_parents = 1,
3341                        .flags = CLK_SET_RATE_PARENT,
3342                        .ops = &clk_branch2_ops,
3343                },
3344        },
3345};
3346
3347static struct clk_branch gcc_ubi0_ahb_clk = {
3348        .halt_reg = 0x6820c,
3349        .clkr = {
3350                .enable_reg = 0x6820c,
3351                .enable_mask = BIT(0),
3352                .hw.init = &(struct clk_init_data){
3353                        .name = "gcc_ubi0_ahb_clk",
3354                        .parent_names = (const char *[]){
3355                                "nss_ce_clk_src"
3356                        },
3357                        .num_parents = 1,
3358                        .flags = CLK_SET_RATE_PARENT,
3359                        .ops = &clk_branch2_ops,
3360                },
3361        },
3362};
3363
3364static struct clk_branch gcc_ubi0_axi_clk = {
3365        .halt_reg = 0x68200,
3366        .clkr = {
3367                .enable_reg = 0x68200,
3368                .enable_mask = BIT(0),
3369                .hw.init = &(struct clk_init_data){
3370                        .name = "gcc_ubi0_axi_clk",
3371                        .parent_names = (const char *[]){
3372                                "nss_noc_clk_src"
3373                        },
3374                        .num_parents = 1,
3375                        .flags = CLK_SET_RATE_PARENT,
3376                        .ops = &clk_branch2_ops,
3377                },
3378        },
3379};
3380
3381static struct clk_branch gcc_ubi0_nc_axi_clk = {
3382        .halt_reg = 0x68204,
3383        .clkr = {
3384                .enable_reg = 0x68204,
3385                .enable_mask = BIT(0),
3386                .hw.init = &(struct clk_init_data){
3387                        .name = "gcc_ubi0_nc_axi_clk",
3388                        .parent_names = (const char *[]){
3389                                "nss_noc_clk_src"
3390                        },
3391                        .num_parents = 1,
3392                        .flags = CLK_SET_RATE_PARENT,
3393                        .ops = &clk_branch2_ops,
3394                },
3395        },
3396};
3397
3398static struct clk_branch gcc_ubi0_core_clk = {
3399        .halt_reg = 0x68210,
3400        .clkr = {
3401                .enable_reg = 0x68210,
3402                .enable_mask = BIT(0),
3403                .hw.init = &(struct clk_init_data){
3404                        .name = "gcc_ubi0_core_clk",
3405                        .parent_names = (const char *[]){
3406                                "nss_ubi0_div_clk_src"
3407                        },
3408                        .num_parents = 1,
3409                        .flags = CLK_SET_RATE_PARENT,
3410                        .ops = &clk_branch2_ops,
3411                },
3412        },
3413};
3414
3415static struct clk_branch gcc_ubi0_mpt_clk = {
3416        .halt_reg = 0x68208,
3417        .clkr = {
3418                .enable_reg = 0x68208,
3419                .enable_mask = BIT(0),
3420                .hw.init = &(struct clk_init_data){
3421                        .name = "gcc_ubi0_mpt_clk",
3422                        .parent_names = (const char *[]){
3423                                "ubi_mpt_clk_src"
3424                        },
3425                        .num_parents = 1,
3426                        .flags = CLK_SET_RATE_PARENT,
3427                        .ops = &clk_branch2_ops,
3428                },
3429        },
3430};
3431
3432static struct clk_branch gcc_ubi1_ahb_clk = {
3433        .halt_reg = 0x6822c,
3434        .clkr = {
3435                .enable_reg = 0x6822c,
3436                .enable_mask = BIT(0),
3437                .hw.init = &(struct clk_init_data){
3438                        .name = "gcc_ubi1_ahb_clk",
3439                        .parent_names = (const char *[]){
3440                                "nss_ce_clk_src"
3441                        },
3442                        .num_parents = 1,
3443                        .flags = CLK_SET_RATE_PARENT,
3444                        .ops = &clk_branch2_ops,
3445                },
3446        },
3447};
3448
3449static struct clk_branch gcc_ubi1_axi_clk = {
3450        .halt_reg = 0x68220,
3451        .clkr = {
3452                .enable_reg = 0x68220,
3453                .enable_mask = BIT(0),
3454                .hw.init = &(struct clk_init_data){
3455                        .name = "gcc_ubi1_axi_clk",
3456                        .parent_names = (const char *[]){
3457                                "nss_noc_clk_src"
3458                        },
3459                        .num_parents = 1,
3460                        .flags = CLK_SET_RATE_PARENT,
3461                        .ops = &clk_branch2_ops,
3462                },
3463        },
3464};
3465
3466static struct clk_branch gcc_ubi1_nc_axi_clk = {
3467        .halt_reg = 0x68224,
3468        .clkr = {
3469                .enable_reg = 0x68224,
3470                .enable_mask = BIT(0),
3471                .hw.init = &(struct clk_init_data){
3472                        .name = "gcc_ubi1_nc_axi_clk",
3473                        .parent_names = (const char *[]){
3474                                "nss_noc_clk_src"
3475                        },
3476                        .num_parents = 1,
3477                        .flags = CLK_SET_RATE_PARENT,
3478                        .ops = &clk_branch2_ops,
3479                },
3480        },
3481};
3482
3483static struct clk_branch gcc_ubi1_core_clk = {
3484        .halt_reg = 0x68230,
3485        .clkr = {
3486                .enable_reg = 0x68230,
3487                .enable_mask = BIT(0),
3488                .hw.init = &(struct clk_init_data){
3489                        .name = "gcc_ubi1_core_clk",
3490                        .parent_names = (const char *[]){
3491                                "nss_ubi1_div_clk_src"
3492                        },
3493                        .num_parents = 1,
3494                        .flags = CLK_SET_RATE_PARENT,
3495                        .ops = &clk_branch2_ops,
3496                },
3497        },
3498};
3499
3500static struct clk_branch gcc_ubi1_mpt_clk = {
3501        .halt_reg = 0x68228,
3502        .clkr = {
3503                .enable_reg = 0x68228,
3504                .enable_mask = BIT(0),
3505                .hw.init = &(struct clk_init_data){
3506                        .name = "gcc_ubi1_mpt_clk",
3507                        .parent_names = (const char *[]){
3508                                "ubi_mpt_clk_src"
3509                        },
3510                        .num_parents = 1,
3511                        .flags = CLK_SET_RATE_PARENT,
3512                        .ops = &clk_branch2_ops,
3513                },
3514        },
3515};
3516
3517static struct clk_branch gcc_cmn_12gpll_ahb_clk = {
3518        .halt_reg = 0x56308,
3519        .clkr = {
3520                .enable_reg = 0x56308,
3521                .enable_mask = BIT(0),
3522                .hw.init = &(struct clk_init_data){
3523                        .name = "gcc_cmn_12gpll_ahb_clk",
3524                        .parent_names = (const char *[]){
3525                                "pcnoc_clk_src"
3526                        },
3527                        .num_parents = 1,
3528                        .flags = CLK_SET_RATE_PARENT,
3529                        .ops = &clk_branch2_ops,
3530                },
3531        },
3532};
3533
3534static struct clk_branch gcc_cmn_12gpll_sys_clk = {
3535        .halt_reg = 0x5630c,
3536        .clkr = {
3537                .enable_reg = 0x5630c,
3538                .enable_mask = BIT(0),
3539                .hw.init = &(struct clk_init_data){
3540                        .name = "gcc_cmn_12gpll_sys_clk",
3541                        .parent_names = (const char *[]){
3542                                "gcc_xo_clk_src"
3543                        },
3544                        .num_parents = 1,
3545                        .flags = CLK_SET_RATE_PARENT,
3546                        .ops = &clk_branch2_ops,
3547                },
3548        },
3549};
3550
3551static struct clk_branch gcc_mdio_ahb_clk = {
3552        .halt_reg = 0x58004,
3553        .clkr = {
3554                .enable_reg = 0x58004,
3555                .enable_mask = BIT(0),
3556                .hw.init = &(struct clk_init_data){
3557                        .name = "gcc_mdio_ahb_clk",
3558                        .parent_names = (const char *[]){
3559                                "pcnoc_clk_src"
3560                        },
3561                        .num_parents = 1,
3562                        .flags = CLK_SET_RATE_PARENT,
3563                        .ops = &clk_branch2_ops,
3564                },
3565        },
3566};
3567
3568static struct clk_branch gcc_uniphy0_ahb_clk = {
3569        .halt_reg = 0x56008,
3570        .clkr = {
3571                .enable_reg = 0x56008,
3572                .enable_mask = BIT(0),
3573                .hw.init = &(struct clk_init_data){
3574                        .name = "gcc_uniphy0_ahb_clk",
3575                        .parent_names = (const char *[]){
3576                                "pcnoc_clk_src"
3577                        },
3578                        .num_parents = 1,
3579                        .flags = CLK_SET_RATE_PARENT,
3580                        .ops = &clk_branch2_ops,
3581                },
3582        },
3583};
3584
3585static struct clk_branch gcc_uniphy0_sys_clk = {
3586        .halt_reg = 0x5600c,
3587        .clkr = {
3588                .enable_reg = 0x5600c,
3589                .enable_mask = BIT(0),
3590                .hw.init = &(struct clk_init_data){
3591                        .name = "gcc_uniphy0_sys_clk",
3592                        .parent_names = (const char *[]){
3593                                "gcc_xo_clk_src"
3594                        },
3595                        .num_parents = 1,
3596                        .flags = CLK_SET_RATE_PARENT,
3597                        .ops = &clk_branch2_ops,
3598                },
3599        },
3600};
3601
3602static struct clk_branch gcc_uniphy1_ahb_clk = {
3603        .halt_reg = 0x56108,
3604        .clkr = {
3605                .enable_reg = 0x56108,
3606                .enable_mask = BIT(0),
3607                .hw.init = &(struct clk_init_data){
3608                        .name = "gcc_uniphy1_ahb_clk",
3609                        .parent_names = (const char *[]){
3610                                "pcnoc_clk_src"
3611                        },
3612                        .num_parents = 1,
3613                        .flags = CLK_SET_RATE_PARENT,
3614                        .ops = &clk_branch2_ops,
3615                },
3616        },
3617};
3618
3619static struct clk_branch gcc_uniphy1_sys_clk = {
3620        .halt_reg = 0x5610c,
3621        .clkr = {
3622                .enable_reg = 0x5610c,
3623                .enable_mask = BIT(0),
3624                .hw.init = &(struct clk_init_data){
3625                        .name = "gcc_uniphy1_sys_clk",
3626                        .parent_names = (const char *[]){
3627                                "gcc_xo_clk_src"
3628                        },
3629                        .num_parents = 1,
3630                        .flags = CLK_SET_RATE_PARENT,
3631                        .ops = &clk_branch2_ops,
3632                },
3633        },
3634};
3635
3636static struct clk_branch gcc_uniphy2_ahb_clk = {
3637        .halt_reg = 0x56208,
3638        .clkr = {
3639                .enable_reg = 0x56208,
3640                .enable_mask = BIT(0),
3641                .hw.init = &(struct clk_init_data){
3642                        .name = "gcc_uniphy2_ahb_clk",
3643                        .parent_names = (const char *[]){
3644                                "pcnoc_clk_src"
3645                        },
3646                        .num_parents = 1,
3647                        .flags = CLK_SET_RATE_PARENT,
3648                        .ops = &clk_branch2_ops,
3649                },
3650        },
3651};
3652
3653static struct clk_branch gcc_uniphy2_sys_clk = {
3654        .halt_reg = 0x5620c,
3655        .clkr = {
3656                .enable_reg = 0x5620c,
3657                .enable_mask = BIT(0),
3658                .hw.init = &(struct clk_init_data){
3659                        .name = "gcc_uniphy2_sys_clk",
3660                        .parent_names = (const char *[]){
3661                                "gcc_xo_clk_src"
3662                        },
3663                        .num_parents = 1,
3664                        .flags = CLK_SET_RATE_PARENT,
3665                        .ops = &clk_branch2_ops,
3666                },
3667        },
3668};
3669
3670static struct clk_branch gcc_nss_port1_rx_clk = {
3671        .halt_reg = 0x68240,
3672        .clkr = {
3673                .enable_reg = 0x68240,
3674                .enable_mask = BIT(0),
3675                .hw.init = &(struct clk_init_data){
3676                        .name = "gcc_nss_port1_rx_clk",
3677                        .parent_names = (const char *[]){
3678                                "nss_port1_rx_div_clk_src"
3679                        },
3680                        .num_parents = 1,
3681                        .flags = CLK_SET_RATE_PARENT,
3682                        .ops = &clk_branch2_ops,
3683                },
3684        },
3685};
3686
3687static struct clk_branch gcc_nss_port1_tx_clk = {
3688        .halt_reg = 0x68244,
3689        .clkr = {
3690                .enable_reg = 0x68244,
3691                .enable_mask = BIT(0),
3692                .hw.init = &(struct clk_init_data){
3693                        .name = "gcc_nss_port1_tx_clk",
3694                        .parent_names = (const char *[]){
3695                                "nss_port1_tx_div_clk_src"
3696                        },
3697                        .num_parents = 1,
3698                        .flags = CLK_SET_RATE_PARENT,
3699                        .ops = &clk_branch2_ops,
3700                },
3701        },
3702};
3703
3704static struct clk_branch gcc_nss_port2_rx_clk = {
3705        .halt_reg = 0x68248,
3706        .clkr = {
3707                .enable_reg = 0x68248,
3708                .enable_mask = BIT(0),
3709                .hw.init = &(struct clk_init_data){
3710                        .name = "gcc_nss_port2_rx_clk",
3711                        .parent_names = (const char *[]){
3712                                "nss_port2_rx_div_clk_src"
3713                        },
3714                        .num_parents = 1,
3715                        .flags = CLK_SET_RATE_PARENT,
3716                        .ops = &clk_branch2_ops,
3717                },
3718        },
3719};
3720
3721static struct clk_branch gcc_nss_port2_tx_clk = {
3722        .halt_reg = 0x6824c,
3723        .clkr = {
3724                .enable_reg = 0x6824c,
3725                .enable_mask = BIT(0),
3726                .hw.init = &(struct clk_init_data){
3727                        .name = "gcc_nss_port2_tx_clk",
3728                        .parent_names = (const char *[]){
3729                                "nss_port2_tx_div_clk_src"
3730                        },
3731                        .num_parents = 1,
3732                        .flags = CLK_SET_RATE_PARENT,
3733                        .ops = &clk_branch2_ops,
3734                },
3735        },
3736};
3737
3738static struct clk_branch gcc_nss_port3_rx_clk = {
3739        .halt_reg = 0x68250,
3740        .clkr = {
3741                .enable_reg = 0x68250,
3742                .enable_mask = BIT(0),
3743                .hw.init = &(struct clk_init_data){
3744                        .name = "gcc_nss_port3_rx_clk",
3745                        .parent_names = (const char *[]){
3746                                "nss_port3_rx_div_clk_src"
3747                        },
3748                        .num_parents = 1,
3749                        .flags = CLK_SET_RATE_PARENT,
3750                        .ops = &clk_branch2_ops,
3751                },
3752        },
3753};
3754
3755static struct clk_branch gcc_nss_port3_tx_clk = {
3756        .halt_reg = 0x68254,
3757        .clkr = {
3758                .enable_reg = 0x68254,
3759                .enable_mask = BIT(0),
3760                .hw.init = &(struct clk_init_data){
3761                        .name = "gcc_nss_port3_tx_clk",
3762                        .parent_names = (const char *[]){
3763                                "nss_port3_tx_div_clk_src"
3764                        },
3765                        .num_parents = 1,
3766                        .flags = CLK_SET_RATE_PARENT,
3767                        .ops = &clk_branch2_ops,
3768                },
3769        },
3770};
3771
3772static struct clk_branch gcc_nss_port4_rx_clk = {
3773        .halt_reg = 0x68258,
3774        .clkr = {
3775                .enable_reg = 0x68258,
3776                .enable_mask = BIT(0),
3777                .hw.init = &(struct clk_init_data){
3778                        .name = "gcc_nss_port4_rx_clk",
3779                        .parent_names = (const char *[]){
3780                                "nss_port4_rx_div_clk_src"
3781                        },
3782                        .num_parents = 1,
3783                        .flags = CLK_SET_RATE_PARENT,
3784                        .ops = &clk_branch2_ops,
3785                },
3786        },
3787};
3788
3789static struct clk_branch gcc_nss_port4_tx_clk = {
3790        .halt_reg = 0x6825c,
3791        .clkr = {
3792                .enable_reg = 0x6825c,
3793                .enable_mask = BIT(0),
3794                .hw.init = &(struct clk_init_data){
3795                        .name = "gcc_nss_port4_tx_clk",
3796                        .parent_names = (const char *[]){
3797                                "nss_port4_tx_div_clk_src"
3798                        },
3799                        .num_parents = 1,
3800                        .flags = CLK_SET_RATE_PARENT,
3801                        .ops = &clk_branch2_ops,
3802                },
3803        },
3804};
3805
3806static struct clk_branch gcc_nss_port5_rx_clk = {
3807        .halt_reg = 0x68260,
3808        .clkr = {
3809                .enable_reg = 0x68260,
3810                .enable_mask = BIT(0),
3811                .hw.init = &(struct clk_init_data){
3812                        .name = "gcc_nss_port5_rx_clk",
3813                        .parent_names = (const char *[]){
3814                                "nss_port5_rx_div_clk_src"
3815                        },
3816                        .num_parents = 1,
3817                        .flags = CLK_SET_RATE_PARENT,
3818                        .ops = &clk_branch2_ops,
3819                },
3820        },
3821};
3822
3823static struct clk_branch gcc_nss_port5_tx_clk = {
3824        .halt_reg = 0x68264,
3825        .clkr = {
3826                .enable_reg = 0x68264,
3827                .enable_mask = BIT(0),
3828                .hw.init = &(struct clk_init_data){
3829                        .name = "gcc_nss_port5_tx_clk",
3830                        .parent_names = (const char *[]){
3831                                "nss_port5_tx_div_clk_src"
3832                        },
3833                        .num_parents = 1,
3834                        .flags = CLK_SET_RATE_PARENT,
3835                        .ops = &clk_branch2_ops,
3836                },
3837        },
3838};
3839
3840static struct clk_branch gcc_nss_port6_rx_clk = {
3841        .halt_reg = 0x68268,
3842        .clkr = {
3843                .enable_reg = 0x68268,
3844                .enable_mask = BIT(0),
3845                .hw.init = &(struct clk_init_data){
3846                        .name = "gcc_nss_port6_rx_clk",
3847                        .parent_names = (const char *[]){
3848                                "nss_port6_rx_div_clk_src"
3849                        },
3850                        .num_parents = 1,
3851                        .flags = CLK_SET_RATE_PARENT,
3852                        .ops = &clk_branch2_ops,
3853                },
3854        },
3855};
3856
3857static struct clk_branch gcc_nss_port6_tx_clk = {
3858        .halt_reg = 0x6826c,
3859        .clkr = {
3860                .enable_reg = 0x6826c,
3861                .enable_mask = BIT(0),
3862                .hw.init = &(struct clk_init_data){
3863                        .name = "gcc_nss_port6_tx_clk",
3864                        .parent_names = (const char *[]){
3865                                "nss_port6_tx_div_clk_src"
3866                        },
3867                        .num_parents = 1,
3868                        .flags = CLK_SET_RATE_PARENT,
3869                        .ops = &clk_branch2_ops,
3870                },
3871        },
3872};
3873
3874static struct clk_branch gcc_port1_mac_clk = {
3875        .halt_reg = 0x68320,
3876        .clkr = {
3877                .enable_reg = 0x68320,
3878                .enable_mask = BIT(0),
3879                .hw.init = &(struct clk_init_data){
3880                        .name = "gcc_port1_mac_clk",
3881                        .parent_names = (const char *[]){
3882                                "nss_ppe_clk_src"
3883                        },
3884                        .num_parents = 1,
3885                        .flags = CLK_SET_RATE_PARENT,
3886                        .ops = &clk_branch2_ops,
3887                },
3888        },
3889};
3890
3891static struct clk_branch gcc_port2_mac_clk = {
3892        .halt_reg = 0x68324,
3893        .clkr = {
3894                .enable_reg = 0x68324,
3895                .enable_mask = BIT(0),
3896                .hw.init = &(struct clk_init_data){
3897                        .name = "gcc_port2_mac_clk",
3898                        .parent_names = (const char *[]){
3899                                "nss_ppe_clk_src"
3900                        },
3901                        .num_parents = 1,
3902                        .flags = CLK_SET_RATE_PARENT,
3903                        .ops = &clk_branch2_ops,
3904                },
3905        },
3906};
3907
3908static struct clk_branch gcc_port3_mac_clk = {
3909        .halt_reg = 0x68328,
3910        .clkr = {
3911                .enable_reg = 0x68328,
3912                .enable_mask = BIT(0),
3913                .hw.init = &(struct clk_init_data){
3914                        .name = "gcc_port3_mac_clk",
3915                        .parent_names = (const char *[]){
3916                                "nss_ppe_clk_src"
3917                        },
3918                        .num_parents = 1,
3919                        .flags = CLK_SET_RATE_PARENT,
3920                        .ops = &clk_branch2_ops,
3921                },
3922        },
3923};
3924
3925static struct clk_branch gcc_port4_mac_clk = {
3926        .halt_reg = 0x6832c,
3927        .clkr = {
3928                .enable_reg = 0x6832c,
3929                .enable_mask = BIT(0),
3930                .hw.init = &(struct clk_init_data){
3931                        .name = "gcc_port4_mac_clk",
3932                        .parent_names = (const char *[]){
3933                                "nss_ppe_clk_src"
3934                        },
3935                        .num_parents = 1,
3936                        .flags = CLK_SET_RATE_PARENT,
3937                        .ops = &clk_branch2_ops,
3938                },
3939        },
3940};
3941
3942static struct clk_branch gcc_port5_mac_clk = {
3943        .halt_reg = 0x68330,
3944        .clkr = {
3945                .enable_reg = 0x68330,
3946                .enable_mask = BIT(0),
3947                .hw.init = &(struct clk_init_data){
3948                        .name = "gcc_port5_mac_clk",
3949                        .parent_names = (const char *[]){
3950                                "nss_ppe_clk_src"
3951                        },
3952                        .num_parents = 1,
3953                        .flags = CLK_SET_RATE_PARENT,
3954                        .ops = &clk_branch2_ops,
3955                },
3956        },
3957};
3958
3959static struct clk_branch gcc_port6_mac_clk = {
3960        .halt_reg = 0x68334,
3961        .clkr = {
3962                .enable_reg = 0x68334,
3963                .enable_mask = BIT(0),
3964                .hw.init = &(struct clk_init_data){
3965                        .name = "gcc_port6_mac_clk",
3966                        .parent_names = (const char *[]){
3967                                "nss_ppe_clk_src"
3968                        },
3969                        .num_parents = 1,
3970                        .flags = CLK_SET_RATE_PARENT,
3971                        .ops = &clk_branch2_ops,
3972                },
3973        },
3974};
3975
3976static struct clk_branch gcc_uniphy0_port1_rx_clk = {
3977        .halt_reg = 0x56010,
3978        .clkr = {
3979                .enable_reg = 0x56010,
3980                .enable_mask = BIT(0),
3981                .hw.init = &(struct clk_init_data){
3982                        .name = "gcc_uniphy0_port1_rx_clk",
3983                        .parent_names = (const char *[]){
3984                                "nss_port1_rx_div_clk_src"
3985                        },
3986                        .num_parents = 1,
3987                        .flags = CLK_SET_RATE_PARENT,
3988                        .ops = &clk_branch2_ops,
3989                },
3990        },
3991};
3992
3993static struct clk_branch gcc_uniphy0_port1_tx_clk = {
3994        .halt_reg = 0x56014,
3995        .clkr = {
3996                .enable_reg = 0x56014,
3997                .enable_mask = BIT(0),
3998                .hw.init = &(struct clk_init_data){
3999                        .name = "gcc_uniphy0_port1_tx_clk",
4000                        .parent_names = (const char *[]){
4001                                "nss_port1_tx_div_clk_src"
4002                        },
4003                        .num_parents = 1,
4004                        .flags = CLK_SET_RATE_PARENT,
4005                        .ops = &clk_branch2_ops,
4006                },
4007        },
4008};
4009
4010static struct clk_branch gcc_uniphy0_port2_rx_clk = {
4011        .halt_reg = 0x56018,
4012        .clkr = {
4013                .enable_reg = 0x56018,
4014                .enable_mask = BIT(0),
4015                .hw.init = &(struct clk_init_data){
4016                        .name = "gcc_uniphy0_port2_rx_clk",
4017                        .parent_names = (const char *[]){
4018                                "nss_port2_rx_div_clk_src"
4019                        },
4020                        .num_parents = 1,
4021                        .flags = CLK_SET_RATE_PARENT,
4022                        .ops = &clk_branch2_ops,
4023                },
4024        },
4025};
4026
4027static struct clk_branch gcc_uniphy0_port2_tx_clk = {
4028        .halt_reg = 0x5601c,
4029        .clkr = {
4030                .enable_reg = 0x5601c,
4031                .enable_mask = BIT(0),
4032                .hw.init = &(struct clk_init_data){
4033                        .name = "gcc_uniphy0_port2_tx_clk",
4034                        .parent_names = (const char *[]){
4035                                "nss_port2_tx_div_clk_src"
4036                        },
4037                        .num_parents = 1,
4038                        .flags = CLK_SET_RATE_PARENT,
4039                        .ops = &clk_branch2_ops,
4040                },
4041        },
4042};
4043
4044static struct clk_branch gcc_uniphy0_port3_rx_clk = {
4045        .halt_reg = 0x56020,
4046        .clkr = {
4047                .enable_reg = 0x56020,
4048                .enable_mask = BIT(0),
4049                .hw.init = &(struct clk_init_data){
4050                        .name = "gcc_uniphy0_port3_rx_clk",
4051                        .parent_names = (const char *[]){
4052                                "nss_port3_rx_div_clk_src"
4053                        },
4054                        .num_parents = 1,
4055                        .flags = CLK_SET_RATE_PARENT,
4056                        .ops = &clk_branch2_ops,
4057                },
4058        },
4059};
4060
4061static struct clk_branch gcc_uniphy0_port3_tx_clk = {
4062        .halt_reg = 0x56024,
4063        .clkr = {
4064                .enable_reg = 0x56024,
4065                .enable_mask = BIT(0),
4066                .hw.init = &(struct clk_init_data){
4067                        .name = "gcc_uniphy0_port3_tx_clk",
4068                        .parent_names = (const char *[]){
4069                                "nss_port3_tx_div_clk_src"
4070                        },
4071                        .num_parents = 1,
4072                        .flags = CLK_SET_RATE_PARENT,
4073                        .ops = &clk_branch2_ops,
4074                },
4075        },
4076};
4077
4078static struct clk_branch gcc_uniphy0_port4_rx_clk = {
4079        .halt_reg = 0x56028,
4080        .clkr = {
4081                .enable_reg = 0x56028,
4082                .enable_mask = BIT(0),
4083                .hw.init = &(struct clk_init_data){
4084                        .name = "gcc_uniphy0_port4_rx_clk",
4085                        .parent_names = (const char *[]){
4086                                "nss_port4_rx_div_clk_src"
4087                        },
4088                        .num_parents = 1,
4089                        .flags = CLK_SET_RATE_PARENT,
4090                        .ops = &clk_branch2_ops,
4091                },
4092        },
4093};
4094
4095static struct clk_branch gcc_uniphy0_port4_tx_clk = {
4096        .halt_reg = 0x5602c,
4097        .clkr = {
4098                .enable_reg = 0x5602c,
4099                .enable_mask = BIT(0),
4100                .hw.init = &(struct clk_init_data){
4101                        .name = "gcc_uniphy0_port4_tx_clk",
4102                        .parent_names = (const char *[]){
4103                                "nss_port4_tx_div_clk_src"
4104                        },
4105                        .num_parents = 1,
4106                        .flags = CLK_SET_RATE_PARENT,
4107                        .ops = &clk_branch2_ops,
4108                },
4109        },
4110};
4111
4112static struct clk_branch gcc_uniphy0_port5_rx_clk = {
4113        .halt_reg = 0x56030,
4114        .clkr = {
4115                .enable_reg = 0x56030,
4116                .enable_mask = BIT(0),
4117                .hw.init = &(struct clk_init_data){
4118                        .name = "gcc_uniphy0_port5_rx_clk",
4119                        .parent_names = (const char *[]){
4120                                "nss_port5_rx_div_clk_src"
4121                        },
4122                        .num_parents = 1,
4123                        .flags = CLK_SET_RATE_PARENT,
4124                        .ops = &clk_branch2_ops,
4125                },
4126        },
4127};
4128
4129static struct clk_branch gcc_uniphy0_port5_tx_clk = {
4130        .halt_reg = 0x56034,
4131        .clkr = {
4132                .enable_reg = 0x56034,
4133                .enable_mask = BIT(0),
4134                .hw.init = &(struct clk_init_data){
4135                        .name = "gcc_uniphy0_port5_tx_clk",
4136                        .parent_names = (const char *[]){
4137                                "nss_port5_tx_div_clk_src"
4138                        },
4139                        .num_parents = 1,
4140                        .flags = CLK_SET_RATE_PARENT,
4141                        .ops = &clk_branch2_ops,
4142                },
4143        },
4144};
4145
4146static struct clk_branch gcc_uniphy1_port5_rx_clk = {
4147        .halt_reg = 0x56110,
4148        .clkr = {
4149                .enable_reg = 0x56110,
4150                .enable_mask = BIT(0),
4151                .hw.init = &(struct clk_init_data){
4152                        .name = "gcc_uniphy1_port5_rx_clk",
4153                        .parent_names = (const char *[]){
4154                                "nss_port5_rx_div_clk_src"
4155                        },
4156                        .num_parents = 1,
4157                        .flags = CLK_SET_RATE_PARENT,
4158                        .ops = &clk_branch2_ops,
4159                },
4160        },
4161};
4162
4163static struct clk_branch gcc_uniphy1_port5_tx_clk = {
4164        .halt_reg = 0x56114,
4165        .clkr = {
4166                .enable_reg = 0x56114,
4167                .enable_mask = BIT(0),
4168                .hw.init = &(struct clk_init_data){
4169                        .name = "gcc_uniphy1_port5_tx_clk",
4170                        .parent_names = (const char *[]){
4171                                "nss_port5_tx_div_clk_src"
4172                        },
4173                        .num_parents = 1,
4174                        .flags = CLK_SET_RATE_PARENT,
4175                        .ops = &clk_branch2_ops,
4176                },
4177        },
4178};
4179
4180static struct clk_branch gcc_uniphy2_port6_rx_clk = {
4181        .halt_reg = 0x56210,
4182        .clkr = {
4183                .enable_reg = 0x56210,
4184                .enable_mask = BIT(0),
4185                .hw.init = &(struct clk_init_data){
4186                        .name = "gcc_uniphy2_port6_rx_clk",
4187                        .parent_names = (const char *[]){
4188                                "nss_port6_rx_div_clk_src"
4189                        },
4190                        .num_parents = 1,
4191                        .flags = CLK_SET_RATE_PARENT,
4192                        .ops = &clk_branch2_ops,
4193                },
4194        },
4195};
4196
4197static struct clk_branch gcc_uniphy2_port6_tx_clk = {
4198        .halt_reg = 0x56214,
4199        .clkr = {
4200                .enable_reg = 0x56214,
4201                .enable_mask = BIT(0),
4202                .hw.init = &(struct clk_init_data){
4203                        .name = "gcc_uniphy2_port6_tx_clk",
4204                        .parent_names = (const char *[]){
4205                                "nss_port6_tx_div_clk_src"
4206                        },
4207                        .num_parents = 1,
4208                        .flags = CLK_SET_RATE_PARENT,
4209                        .ops = &clk_branch2_ops,
4210                },
4211        },
4212};
4213
4214static struct clk_branch gcc_crypto_ahb_clk = {
4215        .halt_reg = 0x16024,
4216        .halt_check = BRANCH_HALT_VOTED,
4217        .clkr = {
4218                .enable_reg = 0x0b004,
4219                .enable_mask = BIT(0),
4220                .hw.init = &(struct clk_init_data){
4221                        .name = "gcc_crypto_ahb_clk",
4222                        .parent_names = (const char *[]){
4223                                "pcnoc_clk_src"
4224                        },
4225                        .num_parents = 1,
4226                        .flags = CLK_SET_RATE_PARENT,
4227                        .ops = &clk_branch2_ops,
4228                },
4229        },
4230};
4231
4232static struct clk_branch gcc_crypto_axi_clk = {
4233        .halt_reg = 0x16020,
4234        .halt_check = BRANCH_HALT_VOTED,
4235        .clkr = {
4236                .enable_reg = 0x0b004,
4237                .enable_mask = BIT(1),
4238                .hw.init = &(struct clk_init_data){
4239                        .name = "gcc_crypto_axi_clk",
4240                        .parent_names = (const char *[]){
4241                                "pcnoc_clk_src"
4242                        },
4243                        .num_parents = 1,
4244                        .flags = CLK_SET_RATE_PARENT,
4245                        .ops = &clk_branch2_ops,
4246                },
4247        },
4248};
4249
4250static struct clk_branch gcc_crypto_clk = {
4251        .halt_reg = 0x1601c,
4252        .halt_check = BRANCH_HALT_VOTED,
4253        .clkr = {
4254                .enable_reg = 0x0b004,
4255                .enable_mask = BIT(2),
4256                .hw.init = &(struct clk_init_data){
4257                        .name = "gcc_crypto_clk",
4258                        .parent_names = (const char *[]){
4259                                "crypto_clk_src"
4260                        },
4261                        .num_parents = 1,
4262                        .flags = CLK_SET_RATE_PARENT,
4263                        .ops = &clk_branch2_ops,
4264                },
4265        },
4266};
4267
4268static struct clk_branch gcc_gp1_clk = {
4269        .halt_reg = 0x08000,
4270        .clkr = {
4271                .enable_reg = 0x08000,
4272                .enable_mask = BIT(0),
4273                .hw.init = &(struct clk_init_data){
4274                        .name = "gcc_gp1_clk",
4275                        .parent_names = (const char *[]){
4276                                "gp1_clk_src"
4277                        },
4278                        .num_parents = 1,
4279                        .flags = CLK_SET_RATE_PARENT,
4280                        .ops = &clk_branch2_ops,
4281                },
4282        },
4283};
4284
4285static struct clk_branch gcc_gp2_clk = {
4286        .halt_reg = 0x09000,
4287        .clkr = {
4288                .enable_reg = 0x09000,
4289                .enable_mask = BIT(0),
4290                .hw.init = &(struct clk_init_data){
4291                        .name = "gcc_gp2_clk",
4292                        .parent_names = (const char *[]){
4293                                "gp2_clk_src"
4294                        },
4295                        .num_parents = 1,
4296                        .flags = CLK_SET_RATE_PARENT,
4297                        .ops = &clk_branch2_ops,
4298                },
4299        },
4300};
4301
4302static struct clk_branch gcc_gp3_clk = {
4303        .halt_reg = 0x0a000,
4304        .clkr = {
4305                .enable_reg = 0x0a000,
4306                .enable_mask = BIT(0),
4307                .hw.init = &(struct clk_init_data){
4308                        .name = "gcc_gp3_clk",
4309                        .parent_names = (const char *[]){
4310                                "gp3_clk_src"
4311                        },
4312                        .num_parents = 1,
4313                        .flags = CLK_SET_RATE_PARENT,
4314                        .ops = &clk_branch2_ops,
4315                },
4316        },
4317};
4318
4319static const struct freq_tbl ftbl_pcie_rchng_clk_src[] = {
4320        F(19200000, P_XO, 1, 0, 0),
4321        F(100000000, P_GPLL0, 8, 0, 0),
4322        { }
4323};
4324
4325static struct clk_rcg2 pcie0_rchng_clk_src = {
4326        .cmd_rcgr = 0x75070,
4327        .freq_tbl = ftbl_pcie_rchng_clk_src,
4328        .hid_width = 5,
4329        .parent_map = gcc_xo_gpll0_map,
4330        .clkr.hw.init = &(struct clk_init_data){
4331                .name = "pcie0_rchng_clk_src",
4332                .parent_hws = (const struct clk_hw *[]) {
4333                                &gpll0.clkr.hw },
4334                .num_parents = 2,
4335                .ops = &clk_rcg2_ops,
4336        },
4337};
4338
4339static struct clk_branch gcc_pcie0_rchng_clk = {
4340        .halt_reg = 0x75070,
4341        .halt_bit = 31,
4342        .clkr = {
4343                .enable_reg = 0x75070,
4344                .enable_mask = BIT(1),
4345                .hw.init = &(struct clk_init_data){
4346                        .name = "gcc_pcie0_rchng_clk",
4347                        .parent_hws = (const struct clk_hw *[]){
4348                                &pcie0_rchng_clk_src.clkr.hw,
4349                        },
4350                        .num_parents = 1,
4351                        .flags = CLK_SET_RATE_PARENT,
4352                        .ops = &clk_branch2_ops,
4353                },
4354        },
4355};
4356
4357static struct clk_branch gcc_pcie0_axi_s_bridge_clk = {
4358        .halt_reg = 0x75048,
4359        .halt_bit = 31,
4360        .clkr = {
4361                .enable_reg = 0x75048,
4362                .enable_mask = BIT(0),
4363                .hw.init = &(struct clk_init_data){
4364                        .name = "gcc_pcie0_axi_s_bridge_clk",
4365                        .parent_hws = (const struct clk_hw *[]){
4366                                &pcie0_axi_clk_src.clkr.hw,
4367                        },
4368                        .num_parents = 1,
4369                        .flags = CLK_SET_RATE_PARENT,
4370                        .ops = &clk_branch2_ops,
4371                },
4372        },
4373};
4374
4375static struct clk_hw *gcc_ipq8074_hws[] = {
4376        &gpll0_out_main_div2.hw,
4377        &gpll6_out_main_div2.hw,
4378        &pcnoc_clk_src.hw,
4379        &system_noc_clk_src.hw,
4380        &gcc_xo_div4_clk_src.hw,
4381        &nss_noc_clk_src.hw,
4382        &nss_ppe_cdiv_clk_src.hw,
4383};
4384
4385static struct clk_regmap *gcc_ipq8074_clks[] = {
4386        [GPLL0_MAIN] = &gpll0_main.clkr,
4387        [GPLL0] = &gpll0.clkr,
4388        [GPLL2_MAIN] = &gpll2_main.clkr,
4389        [GPLL2] = &gpll2.clkr,
4390        [GPLL4_MAIN] = &gpll4_main.clkr,
4391        [GPLL4] = &gpll4.clkr,
4392        [GPLL6_MAIN] = &gpll6_main.clkr,
4393        [GPLL6] = &gpll6.clkr,
4394        [UBI32_PLL_MAIN] = &ubi32_pll_main.clkr,
4395        [UBI32_PLL] = &ubi32_pll.clkr,
4396        [NSS_CRYPTO_PLL_MAIN] = &nss_crypto_pll_main.clkr,
4397        [NSS_CRYPTO_PLL] = &nss_crypto_pll.clkr,
4398        [PCNOC_BFDCD_CLK_SRC] = &pcnoc_bfdcd_clk_src.clkr,
4399        [GCC_SLEEP_CLK_SRC] = &gcc_sleep_clk_src.clkr,
4400        [BLSP1_QUP1_I2C_APPS_CLK_SRC] = &blsp1_qup1_i2c_apps_clk_src.clkr,
4401        [BLSP1_QUP1_SPI_APPS_CLK_SRC] = &blsp1_qup1_spi_apps_clk_src.clkr,
4402        [BLSP1_QUP2_I2C_APPS_CLK_SRC] = &blsp1_qup2_i2c_apps_clk_src.clkr,
4403        [BLSP1_QUP2_SPI_APPS_CLK_SRC] = &blsp1_qup2_spi_apps_clk_src.clkr,
4404        [BLSP1_QUP3_I2C_APPS_CLK_SRC] = &blsp1_qup3_i2c_apps_clk_src.clkr,
4405        [BLSP1_QUP3_SPI_APPS_CLK_SRC] = &blsp1_qup3_spi_apps_clk_src.clkr,
4406        [BLSP1_QUP4_I2C_APPS_CLK_SRC] = &blsp1_qup4_i2c_apps_clk_src.clkr,
4407        [BLSP1_QUP4_SPI_APPS_CLK_SRC] = &blsp1_qup4_spi_apps_clk_src.clkr,
4408        [BLSP1_QUP5_I2C_APPS_CLK_SRC] = &blsp1_qup5_i2c_apps_clk_src.clkr,
4409        [BLSP1_QUP5_SPI_APPS_CLK_SRC] = &blsp1_qup5_spi_apps_clk_src.clkr,
4410        [BLSP1_QUP6_I2C_APPS_CLK_SRC] = &blsp1_qup6_i2c_apps_clk_src.clkr,
4411        [BLSP1_QUP6_SPI_APPS_CLK_SRC] = &blsp1_qup6_spi_apps_clk_src.clkr,
4412        [BLSP1_UART1_APPS_CLK_SRC] = &blsp1_uart1_apps_clk_src.clkr,
4413        [BLSP1_UART2_APPS_CLK_SRC] = &blsp1_uart2_apps_clk_src.clkr,
4414        [BLSP1_UART3_APPS_CLK_SRC] = &blsp1_uart3_apps_clk_src.clkr,
4415        [BLSP1_UART4_APPS_CLK_SRC] = &blsp1_uart4_apps_clk_src.clkr,
4416        [BLSP1_UART5_APPS_CLK_SRC] = &blsp1_uart5_apps_clk_src.clkr,
4417        [BLSP1_UART6_APPS_CLK_SRC] = &blsp1_uart6_apps_clk_src.clkr,
4418        [PCIE0_AXI_CLK_SRC] = &pcie0_axi_clk_src.clkr,
4419        [PCIE0_AUX_CLK_SRC] = &pcie0_aux_clk_src.clkr,
4420        [PCIE0_PIPE_CLK_SRC] = &pcie0_pipe_clk_src.clkr,
4421        [PCIE1_AXI_CLK_SRC] = &pcie1_axi_clk_src.clkr,
4422        [PCIE1_AUX_CLK_SRC] = &pcie1_aux_clk_src.clkr,
4423        [PCIE1_PIPE_CLK_SRC] = &pcie1_pipe_clk_src.clkr,
4424        [SDCC1_APPS_CLK_SRC] = &sdcc1_apps_clk_src.clkr,
4425        [SDCC1_ICE_CORE_CLK_SRC] = &sdcc1_ice_core_clk_src.clkr,
4426        [SDCC2_APPS_CLK_SRC] = &sdcc2_apps_clk_src.clkr,
4427        [USB0_MASTER_CLK_SRC] = &usb0_master_clk_src.clkr,
4428        [USB0_AUX_CLK_SRC] = &usb0_aux_clk_src.clkr,
4429        [USB0_MOCK_UTMI_CLK_SRC] = &usb0_mock_utmi_clk_src.clkr,
4430        [USB0_PIPE_CLK_SRC] = &usb0_pipe_clk_src.clkr,
4431        [USB1_MASTER_CLK_SRC] = &usb1_master_clk_src.clkr,
4432        [USB1_AUX_CLK_SRC] = &usb1_aux_clk_src.clkr,
4433        [USB1_MOCK_UTMI_CLK_SRC] = &usb1_mock_utmi_clk_src.clkr,
4434        [USB1_PIPE_CLK_SRC] = &usb1_pipe_clk_src.clkr,
4435        [GCC_XO_CLK_SRC] = &gcc_xo_clk_src.clkr,
4436        [SYSTEM_NOC_BFDCD_CLK_SRC] = &system_noc_bfdcd_clk_src.clkr,
4437        [NSS_CE_CLK_SRC] = &nss_ce_clk_src.clkr,
4438        [NSS_NOC_BFDCD_CLK_SRC] = &nss_noc_bfdcd_clk_src.clkr,
4439        [NSS_CRYPTO_CLK_SRC] = &nss_crypto_clk_src.clkr,
4440        [NSS_UBI0_CLK_SRC] = &nss_ubi0_clk_src.clkr,
4441        [NSS_UBI0_DIV_CLK_SRC] = &nss_ubi0_div_clk_src.clkr,
4442        [NSS_UBI1_CLK_SRC] = &nss_ubi1_clk_src.clkr,
4443        [NSS_UBI1_DIV_CLK_SRC] = &nss_ubi1_div_clk_src.clkr,
4444        [UBI_MPT_CLK_SRC] = &ubi_mpt_clk_src.clkr,
4445        [NSS_IMEM_CLK_SRC] = &nss_imem_clk_src.clkr,
4446        [NSS_PPE_CLK_SRC] = &nss_ppe_clk_src.clkr,
4447        [NSS_PORT1_RX_CLK_SRC] = &nss_port1_rx_clk_src.clkr,
4448        [NSS_PORT1_RX_DIV_CLK_SRC] = &nss_port1_rx_div_clk_src.clkr,
4449        [NSS_PORT1_TX_CLK_SRC] = &nss_port1_tx_clk_src.clkr,
4450        [NSS_PORT1_TX_DIV_CLK_SRC] = &nss_port1_tx_div_clk_src.clkr,
4451        [NSS_PORT2_RX_CLK_SRC] = &nss_port2_rx_clk_src.clkr,
4452        [NSS_PORT2_RX_DIV_CLK_SRC] = &nss_port2_rx_div_clk_src.clkr,
4453        [NSS_PORT2_TX_CLK_SRC] = &nss_port2_tx_clk_src.clkr,
4454        [NSS_PORT2_TX_DIV_CLK_SRC] = &nss_port2_tx_div_clk_src.clkr,
4455        [NSS_PORT3_RX_CLK_SRC] = &nss_port3_rx_clk_src.clkr,
4456        [NSS_PORT3_RX_DIV_CLK_SRC] = &nss_port3_rx_div_clk_src.clkr,
4457        [NSS_PORT3_TX_CLK_SRC] = &nss_port3_tx_clk_src.clkr,
4458        [NSS_PORT3_TX_DIV_CLK_SRC] = &nss_port3_tx_div_clk_src.clkr,
4459        [NSS_PORT4_RX_CLK_SRC] = &nss_port4_rx_clk_src.clkr,
4460        [NSS_PORT4_RX_DIV_CLK_SRC] = &nss_port4_rx_div_clk_src.clkr,
4461        [NSS_PORT4_TX_CLK_SRC] = &nss_port4_tx_clk_src.clkr,
4462        [NSS_PORT4_TX_DIV_CLK_SRC] = &nss_port4_tx_div_clk_src.clkr,
4463        [NSS_PORT5_RX_CLK_SRC] = &nss_port5_rx_clk_src.clkr,
4464        [NSS_PORT5_RX_DIV_CLK_SRC] = &nss_port5_rx_div_clk_src.clkr,
4465        [NSS_PORT5_TX_CLK_SRC] = &nss_port5_tx_clk_src.clkr,
4466        [NSS_PORT5_TX_DIV_CLK_SRC] = &nss_port5_tx_div_clk_src.clkr,
4467        [NSS_PORT6_RX_CLK_SRC] = &nss_port6_rx_clk_src.clkr,
4468        [NSS_PORT6_RX_DIV_CLK_SRC] = &nss_port6_rx_div_clk_src.clkr,
4469        [NSS_PORT6_TX_CLK_SRC] = &nss_port6_tx_clk_src.clkr,
4470        [NSS_PORT6_TX_DIV_CLK_SRC] = &nss_port6_tx_div_clk_src.clkr,
4471        [CRYPTO_CLK_SRC] = &crypto_clk_src.clkr,
4472        [GP1_CLK_SRC] = &gp1_clk_src.clkr,
4473        [GP2_CLK_SRC] = &gp2_clk_src.clkr,
4474        [GP3_CLK_SRC] = &gp3_clk_src.clkr,
4475        [GCC_BLSP1_AHB_CLK] = &gcc_blsp1_ahb_clk.clkr,
4476        [GCC_BLSP1_QUP1_I2C_APPS_CLK] = &gcc_blsp1_qup1_i2c_apps_clk.clkr,
4477        [GCC_BLSP1_QUP1_SPI_APPS_CLK] = &gcc_blsp1_qup1_spi_apps_clk.clkr,
4478        [GCC_BLSP1_QUP2_I2C_APPS_CLK] = &gcc_blsp1_qup2_i2c_apps_clk.clkr,
4479        [GCC_BLSP1_QUP2_SPI_APPS_CLK] = &gcc_blsp1_qup2_spi_apps_clk.clkr,
4480        [GCC_BLSP1_QUP3_I2C_APPS_CLK] = &gcc_blsp1_qup3_i2c_apps_clk.clkr,
4481        [GCC_BLSP1_QUP3_SPI_APPS_CLK] = &gcc_blsp1_qup3_spi_apps_clk.clkr,
4482        [GCC_BLSP1_QUP4_I2C_APPS_CLK] = &gcc_blsp1_qup4_i2c_apps_clk.clkr,
4483        [GCC_BLSP1_QUP4_SPI_APPS_CLK] = &gcc_blsp1_qup4_spi_apps_clk.clkr,
4484        [GCC_BLSP1_QUP5_I2C_APPS_CLK] = &gcc_blsp1_qup5_i2c_apps_clk.clkr,
4485        [GCC_BLSP1_QUP5_SPI_APPS_CLK] = &gcc_blsp1_qup5_spi_apps_clk.clkr,
4486        [GCC_BLSP1_QUP6_I2C_APPS_CLK] = &gcc_blsp1_qup6_i2c_apps_clk.clkr,
4487        [GCC_BLSP1_QUP6_SPI_APPS_CLK] = &gcc_blsp1_qup6_spi_apps_clk.clkr,
4488        [GCC_BLSP1_UART1_APPS_CLK] = &gcc_blsp1_uart1_apps_clk.clkr,
4489        [GCC_BLSP1_UART2_APPS_CLK] = &gcc_blsp1_uart2_apps_clk.clkr,
4490        [GCC_BLSP1_UART3_APPS_CLK] = &gcc_blsp1_uart3_apps_clk.clkr,
4491        [GCC_BLSP1_UART4_APPS_CLK] = &gcc_blsp1_uart4_apps_clk.clkr,
4492        [GCC_BLSP1_UART5_APPS_CLK] = &gcc_blsp1_uart5_apps_clk.clkr,
4493        [GCC_BLSP1_UART6_APPS_CLK] = &gcc_blsp1_uart6_apps_clk.clkr,
4494        [GCC_PRNG_AHB_CLK] = &gcc_prng_ahb_clk.clkr,
4495        [GCC_QPIC_AHB_CLK] = &gcc_qpic_ahb_clk.clkr,
4496        [GCC_QPIC_CLK] = &gcc_qpic_clk.clkr,
4497        [GCC_PCIE0_AHB_CLK] = &gcc_pcie0_ahb_clk.clkr,
4498        [GCC_PCIE0_AUX_CLK] = &gcc_pcie0_aux_clk.clkr,
4499        [GCC_PCIE0_AXI_M_CLK] = &gcc_pcie0_axi_m_clk.clkr,
4500        [GCC_PCIE0_AXI_S_CLK] = &gcc_pcie0_axi_s_clk.clkr,
4501        [GCC_PCIE0_PIPE_CLK] = &gcc_pcie0_pipe_clk.clkr,
4502        [GCC_SYS_NOC_PCIE0_AXI_CLK] = &gcc_sys_noc_pcie0_axi_clk.clkr,
4503        [GCC_PCIE1_AHB_CLK] = &gcc_pcie1_ahb_clk.clkr,
4504        [GCC_PCIE1_AUX_CLK] = &gcc_pcie1_aux_clk.clkr,
4505        [GCC_PCIE1_AXI_M_CLK] = &gcc_pcie1_axi_m_clk.clkr,
4506        [GCC_PCIE1_AXI_S_CLK] = &gcc_pcie1_axi_s_clk.clkr,
4507        [GCC_PCIE1_PIPE_CLK] = &gcc_pcie1_pipe_clk.clkr,
4508        [GCC_SYS_NOC_PCIE1_AXI_CLK] = &gcc_sys_noc_pcie1_axi_clk.clkr,
4509        [GCC_USB0_AUX_CLK] = &gcc_usb0_aux_clk.clkr,
4510        [GCC_SYS_NOC_USB0_AXI_CLK] = &gcc_sys_noc_usb0_axi_clk.clkr,
4511        [GCC_USB0_MASTER_CLK] = &gcc_usb0_master_clk.clkr,
4512        [GCC_USB0_MOCK_UTMI_CLK] = &gcc_usb0_mock_utmi_clk.clkr,
4513        [GCC_USB0_PHY_CFG_AHB_CLK] = &gcc_usb0_phy_cfg_ahb_clk.clkr,
4514        [GCC_USB0_PIPE_CLK] = &gcc_usb0_pipe_clk.clkr,
4515        [GCC_USB0_SLEEP_CLK] = &gcc_usb0_sleep_clk.clkr,
4516        [GCC_USB1_AUX_CLK] = &gcc_usb1_aux_clk.clkr,
4517        [GCC_SYS_NOC_USB1_AXI_CLK] = &gcc_sys_noc_usb1_axi_clk.clkr,
4518        [GCC_USB1_MASTER_CLK] = &gcc_usb1_master_clk.clkr,
4519        [GCC_USB1_MOCK_UTMI_CLK] = &gcc_usb1_mock_utmi_clk.clkr,
4520        [GCC_USB1_PHY_CFG_AHB_CLK] = &gcc_usb1_phy_cfg_ahb_clk.clkr,
4521        [GCC_USB1_PIPE_CLK] = &gcc_usb1_pipe_clk.clkr,
4522        [GCC_USB1_SLEEP_CLK] = &gcc_usb1_sleep_clk.clkr,
4523        [GCC_SDCC1_AHB_CLK] = &gcc_sdcc1_ahb_clk.clkr,
4524        [GCC_SDCC1_APPS_CLK] = &gcc_sdcc1_apps_clk.clkr,
4525        [GCC_SDCC1_ICE_CORE_CLK] = &gcc_sdcc1_ice_core_clk.clkr,
4526        [GCC_SDCC2_AHB_CLK] = &gcc_sdcc2_ahb_clk.clkr,
4527        [GCC_SDCC2_APPS_CLK] = &gcc_sdcc2_apps_clk.clkr,
4528        [GCC_MEM_NOC_NSS_AXI_CLK] = &gcc_mem_noc_nss_axi_clk.clkr,
4529        [GCC_NSS_CE_APB_CLK] = &gcc_nss_ce_apb_clk.clkr,
4530        [GCC_NSS_CE_AXI_CLK] = &gcc_nss_ce_axi_clk.clkr,
4531        [GCC_NSS_CFG_CLK] = &gcc_nss_cfg_clk.clkr,
4532        [GCC_NSS_CRYPTO_CLK] = &gcc_nss_crypto_clk.clkr,
4533        [GCC_NSS_CSR_CLK] = &gcc_nss_csr_clk.clkr,
4534        [GCC_NSS_EDMA_CFG_CLK] = &gcc_nss_edma_cfg_clk.clkr,
4535        [GCC_NSS_EDMA_CLK] = &gcc_nss_edma_clk.clkr,
4536        [GCC_NSS_IMEM_CLK] = &gcc_nss_imem_clk.clkr,
4537        [GCC_NSS_NOC_CLK] = &gcc_nss_noc_clk.clkr,
4538        [GCC_NSS_PPE_BTQ_CLK] = &gcc_nss_ppe_btq_clk.clkr,
4539        [GCC_NSS_PPE_CFG_CLK] = &gcc_nss_ppe_cfg_clk.clkr,
4540        [GCC_NSS_PPE_CLK] = &gcc_nss_ppe_clk.clkr,
4541        [GCC_NSS_PPE_IPE_CLK] = &gcc_nss_ppe_ipe_clk.clkr,
4542        [GCC_NSS_PTP_REF_CLK] = &gcc_nss_ptp_ref_clk.clkr,
4543        [GCC_NSSNOC_CE_APB_CLK] = &gcc_nssnoc_ce_apb_clk.clkr,
4544        [GCC_NSSNOC_CE_AXI_CLK] = &gcc_nssnoc_ce_axi_clk.clkr,
4545        [GCC_NSSNOC_CRYPTO_CLK] = &gcc_nssnoc_crypto_clk.clkr,
4546        [GCC_NSSNOC_PPE_CFG_CLK] = &gcc_nssnoc_ppe_cfg_clk.clkr,
4547        [GCC_NSSNOC_PPE_CLK] = &gcc_nssnoc_ppe_clk.clkr,
4548        [GCC_NSSNOC_QOSGEN_REF_CLK] = &gcc_nssnoc_qosgen_ref_clk.clkr,
4549        [GCC_NSSNOC_SNOC_CLK] = &gcc_nssnoc_snoc_clk.clkr,
4550        [GCC_NSSNOC_TIMEOUT_REF_CLK] = &gcc_nssnoc_timeout_ref_clk.clkr,
4551        [GCC_NSSNOC_UBI0_AHB_CLK] = &gcc_nssnoc_ubi0_ahb_clk.clkr,
4552        [GCC_NSSNOC_UBI1_AHB_CLK] = &gcc_nssnoc_ubi1_ahb_clk.clkr,
4553        [GCC_UBI0_AHB_CLK] = &gcc_ubi0_ahb_clk.clkr,
4554        [GCC_UBI0_AXI_CLK] = &gcc_ubi0_axi_clk.clkr,
4555        [GCC_UBI0_NC_AXI_CLK] = &gcc_ubi0_nc_axi_clk.clkr,
4556        [GCC_UBI0_CORE_CLK] = &gcc_ubi0_core_clk.clkr,
4557        [GCC_UBI0_MPT_CLK] = &gcc_ubi0_mpt_clk.clkr,
4558        [GCC_UBI1_AHB_CLK] = &gcc_ubi1_ahb_clk.clkr,
4559        [GCC_UBI1_AXI_CLK] = &gcc_ubi1_axi_clk.clkr,
4560        [GCC_UBI1_NC_AXI_CLK] = &gcc_ubi1_nc_axi_clk.clkr,
4561        [GCC_UBI1_CORE_CLK] = &gcc_ubi1_core_clk.clkr,
4562        [GCC_UBI1_MPT_CLK] = &gcc_ubi1_mpt_clk.clkr,
4563        [GCC_CMN_12GPLL_AHB_CLK] = &gcc_cmn_12gpll_ahb_clk.clkr,
4564        [GCC_CMN_12GPLL_SYS_CLK] = &gcc_cmn_12gpll_sys_clk.clkr,
4565        [GCC_MDIO_AHB_CLK] = &gcc_mdio_ahb_clk.clkr,
4566        [GCC_UNIPHY0_AHB_CLK] = &gcc_uniphy0_ahb_clk.clkr,
4567        [GCC_UNIPHY0_SYS_CLK] = &gcc_uniphy0_sys_clk.clkr,
4568        [GCC_UNIPHY1_AHB_CLK] = &gcc_uniphy1_ahb_clk.clkr,
4569        [GCC_UNIPHY1_SYS_CLK] = &gcc_uniphy1_sys_clk.clkr,
4570        [GCC_UNIPHY2_AHB_CLK] = &gcc_uniphy2_ahb_clk.clkr,
4571        [GCC_UNIPHY2_SYS_CLK] = &gcc_uniphy2_sys_clk.clkr,
4572        [GCC_NSS_PORT1_RX_CLK] = &gcc_nss_port1_rx_clk.clkr,
4573        [GCC_NSS_PORT1_TX_CLK] = &gcc_nss_port1_tx_clk.clkr,
4574        [GCC_NSS_PORT2_RX_CLK] = &gcc_nss_port2_rx_clk.clkr,
4575        [GCC_NSS_PORT2_TX_CLK] = &gcc_nss_port2_tx_clk.clkr,
4576        [GCC_NSS_PORT3_RX_CLK] = &gcc_nss_port3_rx_clk.clkr,
4577        [GCC_NSS_PORT3_TX_CLK] = &gcc_nss_port3_tx_clk.clkr,
4578        [GCC_NSS_PORT4_RX_CLK] = &gcc_nss_port4_rx_clk.clkr,
4579        [GCC_NSS_PORT4_TX_CLK] = &gcc_nss_port4_tx_clk.clkr,
4580        [GCC_NSS_PORT5_RX_CLK] = &gcc_nss_port5_rx_clk.clkr,
4581        [GCC_NSS_PORT5_TX_CLK] = &gcc_nss_port5_tx_clk.clkr,
4582        [GCC_NSS_PORT6_RX_CLK] = &gcc_nss_port6_rx_clk.clkr,
4583        [GCC_NSS_PORT6_TX_CLK] = &gcc_nss_port6_tx_clk.clkr,
4584        [GCC_PORT1_MAC_CLK] = &gcc_port1_mac_clk.clkr,
4585        [GCC_PORT2_MAC_CLK] = &gcc_port2_mac_clk.clkr,
4586        [GCC_PORT3_MAC_CLK] = &gcc_port3_mac_clk.clkr,
4587        [GCC_PORT4_MAC_CLK] = &gcc_port4_mac_clk.clkr,
4588        [GCC_PORT5_MAC_CLK] = &gcc_port5_mac_clk.clkr,
4589        [GCC_PORT6_MAC_CLK] = &gcc_port6_mac_clk.clkr,
4590        [GCC_UNIPHY0_PORT1_RX_CLK] = &gcc_uniphy0_port1_rx_clk.clkr,
4591        [GCC_UNIPHY0_PORT1_TX_CLK] = &gcc_uniphy0_port1_tx_clk.clkr,
4592        [GCC_UNIPHY0_PORT2_RX_CLK] = &gcc_uniphy0_port2_rx_clk.clkr,
4593        [GCC_UNIPHY0_PORT2_TX_CLK] = &gcc_uniphy0_port2_tx_clk.clkr,
4594        [GCC_UNIPHY0_PORT3_RX_CLK] = &gcc_uniphy0_port3_rx_clk.clkr,
4595        [GCC_UNIPHY0_PORT3_TX_CLK] = &gcc_uniphy0_port3_tx_clk.clkr,
4596        [GCC_UNIPHY0_PORT4_RX_CLK] = &gcc_uniphy0_port4_rx_clk.clkr,
4597        [GCC_UNIPHY0_PORT4_TX_CLK] = &gcc_uniphy0_port4_tx_clk.clkr,
4598        [GCC_UNIPHY0_PORT5_RX_CLK] = &gcc_uniphy0_port5_rx_clk.clkr,
4599        [GCC_UNIPHY0_PORT5_TX_CLK] = &gcc_uniphy0_port5_tx_clk.clkr,
4600        [GCC_UNIPHY1_PORT5_RX_CLK] = &gcc_uniphy1_port5_rx_clk.clkr,
4601        [GCC_UNIPHY1_PORT5_TX_CLK] = &gcc_uniphy1_port5_tx_clk.clkr,
4602        [GCC_UNIPHY2_PORT6_RX_CLK] = &gcc_uniphy2_port6_rx_clk.clkr,
4603        [GCC_UNIPHY2_PORT6_TX_CLK] = &gcc_uniphy2_port6_tx_clk.clkr,
4604        [GCC_CRYPTO_AHB_CLK] = &gcc_crypto_ahb_clk.clkr,
4605        [GCC_CRYPTO_AXI_CLK] = &gcc_crypto_axi_clk.clkr,
4606        [GCC_CRYPTO_CLK] = &gcc_crypto_clk.clkr,
4607        [GCC_GP1_CLK] = &gcc_gp1_clk.clkr,
4608        [GCC_GP2_CLK] = &gcc_gp2_clk.clkr,
4609        [GCC_GP3_CLK] = &gcc_gp3_clk.clkr,
4610        [GCC_PCIE0_RCHNG_CLK_SRC] = &pcie0_rchng_clk_src.clkr,
4611        [GCC_PCIE0_RCHNG_CLK] = &gcc_pcie0_rchng_clk.clkr,
4612        [GCC_PCIE0_AXI_S_BRIDGE_CLK] = &gcc_pcie0_axi_s_bridge_clk.clkr,
4613};
4614
4615static const struct qcom_reset_map gcc_ipq8074_resets[] = {
4616        [GCC_BLSP1_BCR] = { 0x01000, 0 },
4617        [GCC_BLSP1_QUP1_BCR] = { 0x02000, 0 },
4618        [GCC_BLSP1_UART1_BCR] = { 0x02038, 0 },
4619        [GCC_BLSP1_QUP2_BCR] = { 0x03008, 0 },
4620        [GCC_BLSP1_UART2_BCR] = { 0x03028, 0 },
4621        [GCC_BLSP1_QUP3_BCR] = { 0x04008, 0 },
4622        [GCC_BLSP1_UART3_BCR] = { 0x04028, 0 },
4623        [GCC_BLSP1_QUP4_BCR] = { 0x05008, 0 },
4624        [GCC_BLSP1_UART4_BCR] = { 0x05028, 0 },
4625        [GCC_BLSP1_QUP5_BCR] = { 0x06008, 0 },
4626        [GCC_BLSP1_UART5_BCR] = { 0x06028, 0 },
4627        [GCC_BLSP1_QUP6_BCR] = { 0x07008, 0 },
4628        [GCC_BLSP1_UART6_BCR] = { 0x07028, 0 },
4629        [GCC_IMEM_BCR] = { 0x0e000, 0 },
4630        [GCC_SMMU_BCR] = { 0x12000, 0 },
4631        [GCC_APSS_TCU_BCR] = { 0x12050, 0 },
4632        [GCC_SMMU_XPU_BCR] = { 0x12054, 0 },
4633        [GCC_PCNOC_TBU_BCR] = { 0x12058, 0 },
4634        [GCC_SMMU_CFG_BCR] = { 0x1208c, 0 },
4635        [GCC_PRNG_BCR] = { 0x13000, 0 },
4636        [GCC_BOOT_ROM_BCR] = { 0x13008, 0 },
4637        [GCC_CRYPTO_BCR] = { 0x16000, 0 },
4638        [GCC_WCSS_BCR] = { 0x18000, 0 },
4639        [GCC_WCSS_Q6_BCR] = { 0x18100, 0 },
4640        [GCC_NSS_BCR] = { 0x19000, 0 },
4641        [GCC_SEC_CTRL_BCR] = { 0x1a000, 0 },
4642        [GCC_ADSS_BCR] = { 0x1c000, 0 },
4643        [GCC_DDRSS_BCR] = { 0x1e000, 0 },
4644        [GCC_SYSTEM_NOC_BCR] = { 0x26000, 0 },
4645        [GCC_PCNOC_BCR] = { 0x27018, 0 },
4646        [GCC_TCSR_BCR] = { 0x28000, 0 },
4647        [GCC_QDSS_BCR] = { 0x29000, 0 },
4648        [GCC_DCD_BCR] = { 0x2a000, 0 },
4649        [GCC_MSG_RAM_BCR] = { 0x2b000, 0 },
4650        [GCC_MPM_BCR] = { 0x2c000, 0 },
4651        [GCC_SPMI_BCR] = { 0x2e000, 0 },
4652        [GCC_SPDM_BCR] = { 0x2f000, 0 },
4653        [GCC_RBCPR_BCR] = { 0x33000, 0 },
4654        [GCC_RBCPR_MX_BCR] = { 0x33014, 0 },
4655        [GCC_TLMM_BCR] = { 0x34000, 0 },
4656        [GCC_RBCPR_WCSS_BCR] = { 0x3a000, 0 },
4657        [GCC_USB0_PHY_BCR] = { 0x3e034, 0 },
4658        [GCC_USB3PHY_0_PHY_BCR] = { 0x3e03c, 0 },
4659        [GCC_USB0_BCR] = { 0x3e070, 0 },
4660        [GCC_USB1_PHY_BCR] = { 0x3f034, 0 },
4661        [GCC_USB3PHY_1_PHY_BCR] = { 0x3f03c, 0 },
4662        [GCC_USB1_BCR] = { 0x3f070, 0 },
4663        [GCC_QUSB2_0_PHY_BCR] = { 0x4103c, 0 },
4664        [GCC_QUSB2_1_PHY_BCR] = { 0x41040, 0 },
4665        [GCC_SDCC1_BCR] = { 0x42000, 0 },
4666        [GCC_SDCC2_BCR] = { 0x43000, 0 },
4667        [GCC_SNOC_BUS_TIMEOUT0_BCR] = { 0x47000, 0 },
4668        [GCC_SNOC_BUS_TIMEOUT2_BCR] = { 0x47008, 0 },
4669        [GCC_SNOC_BUS_TIMEOUT3_BCR] = { 0x47010, 0 },
4670        [GCC_PCNOC_BUS_TIMEOUT0_BCR] = { 0x48000, 0 },
4671        [GCC_PCNOC_BUS_TIMEOUT1_BCR] = { 0x48008, 0 },
4672        [GCC_PCNOC_BUS_TIMEOUT2_BCR] = { 0x48010, 0 },
4673        [GCC_PCNOC_BUS_TIMEOUT3_BCR] = { 0x48018, 0 },
4674        [GCC_PCNOC_BUS_TIMEOUT4_BCR] = { 0x48020, 0 },
4675        [GCC_PCNOC_BUS_TIMEOUT5_BCR] = { 0x48028, 0 },
4676        [GCC_PCNOC_BUS_TIMEOUT6_BCR] = { 0x48030, 0 },
4677        [GCC_PCNOC_BUS_TIMEOUT7_BCR] = { 0x48038, 0 },
4678        [GCC_PCNOC_BUS_TIMEOUT8_BCR] = { 0x48040, 0 },
4679        [GCC_PCNOC_BUS_TIMEOUT9_BCR] = { 0x48048, 0 },
4680        [GCC_UNIPHY0_BCR] = { 0x56000, 0 },
4681        [GCC_UNIPHY1_BCR] = { 0x56100, 0 },
4682        [GCC_UNIPHY2_BCR] = { 0x56200, 0 },
4683        [GCC_CMN_12GPLL_BCR] = { 0x56300, 0 },
4684        [GCC_QPIC_BCR] = { 0x57018, 0 },
4685        [GCC_MDIO_BCR] = { 0x58000, 0 },
4686        [GCC_PCIE1_TBU_BCR] = { 0x65000, 0 },
4687        [GCC_WCSS_CORE_TBU_BCR] = { 0x66000, 0 },
4688        [GCC_WCSS_Q6_TBU_BCR] = { 0x67000, 0 },
4689        [GCC_USB0_TBU_BCR] = { 0x6a000, 0 },
4690        [GCC_USB1_TBU_BCR] = { 0x6a004, 0 },
4691        [GCC_PCIE0_TBU_BCR] = { 0x6b000, 0 },
4692        [GCC_NSS_NOC_TBU_BCR] = { 0x6e000, 0 },
4693        [GCC_PCIE0_BCR] = { 0x75004, 0 },
4694        [GCC_PCIE0_PHY_BCR] = { 0x75038, 0 },
4695        [GCC_PCIE0PHY_PHY_BCR] = { 0x7503c, 0 },
4696        [GCC_PCIE0_LINK_DOWN_BCR] = { 0x75044, 0 },
4697        [GCC_PCIE1_BCR] = { 0x76004, 0 },
4698        [GCC_PCIE1_PHY_BCR] = { 0x76038, 0 },
4699        [GCC_PCIE1PHY_PHY_BCR] = { 0x7603c, 0 },
4700        [GCC_PCIE1_LINK_DOWN_BCR] = { 0x76044, 0 },
4701        [GCC_DCC_BCR] = { 0x77000, 0 },
4702        [GCC_APC0_VOLTAGE_DROOP_DETECTOR_BCR] = { 0x78000, 0 },
4703        [GCC_APC1_VOLTAGE_DROOP_DETECTOR_BCR] = { 0x79000, 0 },
4704        [GCC_SMMU_CATS_BCR] = { 0x7c000, 0 },
4705        [GCC_UBI0_AXI_ARES] = { 0x68010, 0 },
4706        [GCC_UBI0_AHB_ARES] = { 0x68010, 1 },
4707        [GCC_UBI0_NC_AXI_ARES] = { 0x68010, 2 },
4708        [GCC_UBI0_DBG_ARES] = { 0x68010, 3 },
4709        [GCC_UBI0_CORE_CLAMP_ENABLE] = { 0x68010, 4 },
4710        [GCC_UBI0_CLKRST_CLAMP_ENABLE] = { 0x68010, 5 },
4711        [GCC_UBI1_AXI_ARES] = { 0x68010, 8 },
4712        [GCC_UBI1_AHB_ARES] = { 0x68010, 9 },
4713        [GCC_UBI1_NC_AXI_ARES] = { 0x68010, 10 },
4714        [GCC_UBI1_DBG_ARES] = { 0x68010, 11 },
4715        [GCC_UBI1_CORE_CLAMP_ENABLE] = { 0x68010, 12 },
4716        [GCC_UBI1_CLKRST_CLAMP_ENABLE] = { 0x68010, 13 },
4717        [GCC_NSS_CFG_ARES] = { 0x68010, 16 },
4718        [GCC_NSS_IMEM_ARES] = { 0x68010, 17 },
4719        [GCC_NSS_NOC_ARES] = { 0x68010, 18 },
4720        [GCC_NSS_CRYPTO_ARES] = { 0x68010, 19 },
4721        [GCC_NSS_CSR_ARES] = { 0x68010, 20 },
4722        [GCC_NSS_CE_APB_ARES] = { 0x68010, 21 },
4723        [GCC_NSS_CE_AXI_ARES] = { 0x68010, 22 },
4724        [GCC_NSSNOC_CE_APB_ARES] = { 0x68010, 23 },
4725        [GCC_NSSNOC_CE_AXI_ARES] = { 0x68010, 24 },
4726        [GCC_NSSNOC_UBI0_AHB_ARES] = { 0x68010, 25 },
4727        [GCC_NSSNOC_UBI1_AHB_ARES] = { 0x68010, 26 },
4728        [GCC_NSSNOC_SNOC_ARES] = { 0x68010, 27 },
4729        [GCC_NSSNOC_CRYPTO_ARES] = { 0x68010, 28 },
4730        [GCC_NSSNOC_ATB_ARES] = { 0x68010, 29 },
4731        [GCC_NSSNOC_QOSGEN_REF_ARES] = { 0x68010, 30 },
4732        [GCC_NSSNOC_TIMEOUT_REF_ARES] = { 0x68010, 31 },
4733        [GCC_PCIE0_PIPE_ARES] = { 0x75040, 0 },
4734        [GCC_PCIE0_SLEEP_ARES] = { 0x75040, 1 },
4735        [GCC_PCIE0_CORE_STICKY_ARES] = { 0x75040, 2 },
4736        [GCC_PCIE0_AXI_MASTER_ARES] = { 0x75040, 3 },
4737        [GCC_PCIE0_AXI_SLAVE_ARES] = { 0x75040, 4 },
4738        [GCC_PCIE0_AHB_ARES] = { 0x75040, 5 },
4739        [GCC_PCIE0_AXI_MASTER_STICKY_ARES] = { 0x75040, 6 },
4740        [GCC_PCIE0_AXI_SLAVE_STICKY_ARES] = { 0x75040, 7 },
4741        [GCC_PCIE1_PIPE_ARES] = { 0x76040, 0 },
4742        [GCC_PCIE1_SLEEP_ARES] = { 0x76040, 1 },
4743        [GCC_PCIE1_CORE_STICKY_ARES] = { 0x76040, 2 },
4744        [GCC_PCIE1_AXI_MASTER_ARES] = { 0x76040, 3 },
4745        [GCC_PCIE1_AXI_SLAVE_ARES] = { 0x76040, 4 },
4746        [GCC_PCIE1_AHB_ARES] = { 0x76040, 5 },
4747        [GCC_PCIE1_AXI_MASTER_STICKY_ARES] = { 0x76040, 6 },
4748};
4749
4750static const struct of_device_id gcc_ipq8074_match_table[] = {
4751        { .compatible = "qcom,gcc-ipq8074" },
4752        { }
4753};
4754MODULE_DEVICE_TABLE(of, gcc_ipq8074_match_table);
4755
4756static const struct regmap_config gcc_ipq8074_regmap_config = {
4757        .reg_bits       = 32,
4758        .reg_stride     = 4,
4759        .val_bits       = 32,
4760        .max_register   = 0x7fffc,
4761        .fast_io        = true,
4762};
4763
4764static const struct qcom_cc_desc gcc_ipq8074_desc = {
4765        .config = &gcc_ipq8074_regmap_config,
4766        .clks = gcc_ipq8074_clks,
4767        .num_clks = ARRAY_SIZE(gcc_ipq8074_clks),
4768        .resets = gcc_ipq8074_resets,
4769        .num_resets = ARRAY_SIZE(gcc_ipq8074_resets),
4770        .clk_hws = gcc_ipq8074_hws,
4771        .num_clk_hws = ARRAY_SIZE(gcc_ipq8074_hws),
4772};
4773
4774static int gcc_ipq8074_probe(struct platform_device *pdev)
4775{
4776        return qcom_cc_probe(pdev, &gcc_ipq8074_desc);
4777}
4778
4779static struct platform_driver gcc_ipq8074_driver = {
4780        .probe = gcc_ipq8074_probe,
4781        .driver = {
4782                .name   = "qcom,gcc-ipq8074",
4783                .of_match_table = gcc_ipq8074_match_table,
4784        },
4785};
4786
4787static int __init gcc_ipq8074_init(void)
4788{
4789        return platform_driver_register(&gcc_ipq8074_driver);
4790}
4791core_initcall(gcc_ipq8074_init);
4792
4793static void __exit gcc_ipq8074_exit(void)
4794{
4795        platform_driver_unregister(&gcc_ipq8074_driver);
4796}
4797module_exit(gcc_ipq8074_exit);
4798
4799MODULE_DESCRIPTION("QCOM GCC IPQ8074 Driver");
4800MODULE_LICENSE("GPL v2");
4801MODULE_ALIAS("platform:gcc-ipq8074");
4802