1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * Copyright (c) 2021, The Linux Foundation. All rights reserved. 4 * Copyright (c) 2022, Linaro Ltd. 5 */ 6 7 #include <linux/clk-provider.h> 8 #include <linux/err.h> 9 #include <linux/kernel.h> 10 #include <linux/module.h> 11 #include <linux/pm_runtime.h> 12 #include <linux/of.h> 13 #include <linux/platform_device.h> 14 #include <linux/regmap.h> 15 16 #include <dt-bindings/clock/qcom,gcc-sc8280xp.h> 17 18 #include "clk-alpha-pll.h" 19 #include "clk-branch.h" 20 #include "clk-rcg.h" 21 #include "clk-regmap.h" 22 #include "clk-regmap-divider.h" 23 #include "clk-regmap-mux.h" 24 #include "clk-regmap-phy-mux.h" 25 #include "common.h" 26 #include "gdsc.h" 27 #include "reset.h" 28 29 /* Need to match the order of clocks in DT binding */ 30 enum { 31 DT_BI_TCXO, 32 DT_SLEEP_CLK, 33 DT_UFS_PHY_RX_SYMBOL_0_CLK, 34 DT_UFS_PHY_RX_SYMBOL_1_CLK, 35 DT_UFS_PHY_TX_SYMBOL_0_CLK, 36 DT_UFS_CARD_RX_SYMBOL_0_CLK, 37 DT_UFS_CARD_RX_SYMBOL_1_CLK, 38 DT_UFS_CARD_TX_SYMBOL_0_CLK, 39 DT_USB3_PHY_WRAPPER_GCC_USB30_PIPE_CLK, 40 DT_GCC_USB4_PHY_PIPEGMUX_CLK_SRC, 41 DT_GCC_USB4_PHY_DP_GMUX_CLK_SRC, 42 DT_GCC_USB4_PHY_SYS_PIPEGMUX_CLK_SRC, 43 DT_USB4_PHY_GCC_USB4_PCIE_PIPE_CLK, 44 DT_USB4_PHY_GCC_USB4RTR_MAX_PIPE_CLK, 45 DT_QUSB4PHY_GCC_USB4_RX0_CLK, 46 DT_QUSB4PHY_GCC_USB4_RX1_CLK, 47 DT_USB3_UNI_PHY_SEC_GCC_USB30_PIPE_CLK, 48 DT_GCC_USB4_1_PHY_PIPEGMUX_CLK_SRC, 49 DT_GCC_USB4_1_PHY_DP_GMUX_CLK_SRC, 50 DT_GCC_USB4_1_PHY_SYS_PIPEGMUX_CLK_SRC, 51 DT_USB4_1_PHY_GCC_USB4_PCIE_PIPE_CLK, 52 DT_USB4_1_PHY_GCC_USB4RTR_MAX_PIPE_CLK, 53 DT_QUSB4PHY_1_GCC_USB4_RX0_CLK, 54 DT_QUSB4PHY_1_GCC_USB4_RX1_CLK, 55 DT_USB3_UNI_PHY_MP_GCC_USB30_PIPE_0_CLK, 56 DT_USB3_UNI_PHY_MP_GCC_USB30_PIPE_1_CLK, 57 DT_PCIE_2A_PIPE_CLK, 58 DT_PCIE_2B_PIPE_CLK, 59 DT_PCIE_3A_PIPE_CLK, 60 DT_PCIE_3B_PIPE_CLK, 61 DT_PCIE_4_PIPE_CLK, 62 DT_RXC0_REF_CLK, 63 DT_RXC1_REF_CLK, 64 }; 65 66 enum { 67 P_BI_TCXO, 68 P_GCC_GPLL0_OUT_EVEN, 69 P_GCC_GPLL0_OUT_MAIN, 70 P_GCC_GPLL2_OUT_MAIN, 71 P_GCC_GPLL4_OUT_MAIN, 72 P_GCC_GPLL7_OUT_MAIN, 73 P_GCC_GPLL8_OUT_MAIN, 74 P_GCC_GPLL9_OUT_MAIN, 75 P_GCC_USB3_PRIM_PHY_PIPE_CLK_SRC, 76 P_GCC_USB3_SEC_PHY_PIPE_CLK_SRC, 77 P_GCC_USB4_1_PHY_DP_GMUX_CLK_SRC, 78 P_GCC_USB4_1_PHY_PCIE_PIPE_CLK_SRC, 79 P_GCC_USB4_1_PHY_PCIE_PIPEGMUX_CLK_SRC, 80 P_GCC_USB4_1_PHY_PIPEGMUX_CLK_SRC, 81 P_GCC_USB4_1_PHY_SYS_PIPEGMUX_CLK_SRC, 82 P_GCC_USB4_PHY_DP_GMUX_CLK_SRC, 83 P_GCC_USB4_PHY_PCIE_PIPE_CLK_SRC, 84 P_GCC_USB4_PHY_PCIE_PIPEGMUX_CLK_SRC, 85 P_GCC_USB4_PHY_PIPEGMUX_CLK_SRC, 86 P_GCC_USB4_PHY_SYS_PIPEGMUX_CLK_SRC, 87 P_QUSB4PHY_1_GCC_USB4_RX0_CLK, 88 P_QUSB4PHY_1_GCC_USB4_RX1_CLK, 89 P_QUSB4PHY_GCC_USB4_RX0_CLK, 90 P_QUSB4PHY_GCC_USB4_RX1_CLK, 91 P_RXC0_REF_CLK, 92 P_RXC1_REF_CLK, 93 P_SLEEP_CLK, 94 P_UFS_CARD_RX_SYMBOL_0_CLK, 95 P_UFS_CARD_RX_SYMBOL_1_CLK, 96 P_UFS_CARD_TX_SYMBOL_0_CLK, 97 P_UFS_PHY_RX_SYMBOL_0_CLK, 98 P_UFS_PHY_RX_SYMBOL_1_CLK, 99 P_UFS_PHY_TX_SYMBOL_0_CLK, 100 P_USB3_PHY_WRAPPER_GCC_USB30_PIPE_CLK, 101 P_USB3_UNI_PHY_MP_GCC_USB30_PIPE_0_CLK, 102 P_USB3_UNI_PHY_MP_GCC_USB30_PIPE_1_CLK, 103 P_USB3_UNI_PHY_SEC_GCC_USB30_PIPE_CLK, 104 P_USB4_1_PHY_GCC_USB4_PCIE_PIPE_CLK, 105 P_USB4_1_PHY_GCC_USB4RTR_MAX_PIPE_CLK, 106 P_USB4_PHY_GCC_USB4_PCIE_PIPE_CLK, 107 P_USB4_PHY_GCC_USB4RTR_MAX_PIPE_CLK, 108 }; 109 110 static const struct clk_parent_data gcc_parent_data_tcxo = { .index = DT_BI_TCXO }; 111 112 static struct clk_alpha_pll gcc_gpll0 = { 113 .offset = 0x0, 114 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 115 .clkr = { 116 .enable_reg = 0x52028, 117 .enable_mask = BIT(0), 118 .hw.init = &(const struct clk_init_data) { 119 .name = "gcc_gpll0", 120 .parent_data = &gcc_parent_data_tcxo, 121 .num_parents = 1, 122 .ops = &clk_alpha_pll_fixed_lucid_5lpe_ops, 123 }, 124 }, 125 }; 126 127 static const struct clk_div_table post_div_table_gcc_gpll0_out_even[] = { 128 { 0x1, 2 }, 129 { } 130 }; 131 132 static struct clk_alpha_pll_postdiv gcc_gpll0_out_even = { 133 .offset = 0x0, 134 .post_div_shift = 8, 135 .post_div_table = post_div_table_gcc_gpll0_out_even, 136 .num_post_div = ARRAY_SIZE(post_div_table_gcc_gpll0_out_even), 137 .width = 4, 138 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 139 .clkr.hw.init = &(const struct clk_init_data) { 140 .name = "gcc_gpll0_out_even", 141 .parent_hws = (const struct clk_hw*[]){ 142 &gcc_gpll0.clkr.hw, 143 }, 144 .num_parents = 1, 145 .ops = &clk_alpha_pll_postdiv_lucid_5lpe_ops, 146 }, 147 }; 148 149 static struct clk_alpha_pll gcc_gpll2 = { 150 .offset = 0x2000, 151 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 152 .clkr = { 153 .enable_reg = 0x52028, 154 .enable_mask = BIT(2), 155 .hw.init = &(const struct clk_init_data) { 156 .name = "gcc_gpll2", 157 .parent_data = &gcc_parent_data_tcxo, 158 .num_parents = 1, 159 .ops = &clk_alpha_pll_fixed_lucid_5lpe_ops, 160 }, 161 }, 162 }; 163 164 static struct clk_alpha_pll gcc_gpll4 = { 165 .offset = 0x76000, 166 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 167 .clkr = { 168 .enable_reg = 0x52028, 169 .enable_mask = BIT(4), 170 .hw.init = &(const struct clk_init_data) { 171 .name = "gcc_gpll4", 172 .parent_data = &gcc_parent_data_tcxo, 173 .num_parents = 1, 174 .ops = &clk_alpha_pll_fixed_lucid_5lpe_ops, 175 }, 176 }, 177 }; 178 179 static struct clk_alpha_pll gcc_gpll7 = { 180 .offset = 0x1a000, 181 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 182 .clkr = { 183 .enable_reg = 0x52028, 184 .enable_mask = BIT(7), 185 .hw.init = &(const struct clk_init_data) { 186 .name = "gcc_gpll7", 187 .parent_data = &gcc_parent_data_tcxo, 188 .num_parents = 1, 189 .ops = &clk_alpha_pll_fixed_lucid_5lpe_ops, 190 }, 191 }, 192 }; 193 194 static struct clk_alpha_pll gcc_gpll8 = { 195 .offset = 0x1b000, 196 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 197 .clkr = { 198 .enable_reg = 0x52028, 199 .enable_mask = BIT(8), 200 .hw.init = &(const struct clk_init_data) { 201 .name = "gcc_gpll8", 202 .parent_data = &gcc_parent_data_tcxo, 203 .num_parents = 1, 204 .ops = &clk_alpha_pll_fixed_lucid_5lpe_ops, 205 }, 206 }, 207 }; 208 209 static struct clk_alpha_pll gcc_gpll9 = { 210 .offset = 0x1c000, 211 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 212 .clkr = { 213 .enable_reg = 0x52028, 214 .enable_mask = BIT(9), 215 .hw.init = &(const struct clk_init_data) { 216 .name = "gcc_gpll9", 217 .parent_data = &gcc_parent_data_tcxo, 218 .num_parents = 1, 219 .ops = &clk_alpha_pll_fixed_lucid_5lpe_ops, 220 }, 221 }, 222 }; 223 224 static struct clk_rcg2 gcc_usb4_1_phy_pcie_pipe_clk_src; 225 static struct clk_rcg2 gcc_usb4_phy_pcie_pipe_clk_src; 226 227 static const struct parent_map gcc_parent_map_0[] = { 228 { P_BI_TCXO, 0 }, 229 { P_GCC_GPLL0_OUT_MAIN, 1 }, 230 { P_GCC_GPLL0_OUT_EVEN, 6 }, 231 }; 232 233 static const struct clk_parent_data gcc_parent_data_0[] = { 234 { .index = DT_BI_TCXO }, 235 { .hw = &gcc_gpll0.clkr.hw }, 236 { .hw = &gcc_gpll0_out_even.clkr.hw }, 237 }; 238 239 static const struct parent_map gcc_parent_map_1[] = { 240 { P_BI_TCXO, 0 }, 241 { P_SLEEP_CLK, 5 }, 242 }; 243 244 static const struct clk_parent_data gcc_parent_data_1[] = { 245 { .index = DT_BI_TCXO }, 246 { .index = DT_SLEEP_CLK }, 247 }; 248 249 static const struct parent_map gcc_parent_map_2[] = { 250 { P_BI_TCXO, 0 }, 251 { P_GCC_GPLL0_OUT_MAIN, 1 }, 252 { P_SLEEP_CLK, 5 }, 253 { P_GCC_GPLL0_OUT_EVEN, 6 }, 254 }; 255 256 static const struct clk_parent_data gcc_parent_data_2[] = { 257 { .index = DT_BI_TCXO }, 258 { .hw = &gcc_gpll0.clkr.hw }, 259 { .index = DT_SLEEP_CLK }, 260 { .hw = &gcc_gpll0_out_even.clkr.hw }, 261 }; 262 263 static const struct parent_map gcc_parent_map_3[] = { 264 { P_BI_TCXO, 0 }, 265 }; 266 267 static const struct clk_parent_data gcc_parent_data_3[] = { 268 { .index = DT_BI_TCXO }, 269 }; 270 271 static const struct parent_map gcc_parent_map_4[] = { 272 { P_BI_TCXO, 0 }, 273 { P_GCC_GPLL7_OUT_MAIN, 2 }, 274 { P_GCC_GPLL4_OUT_MAIN, 5 }, 275 { P_GCC_GPLL0_OUT_EVEN, 6 }, 276 }; 277 278 static const struct clk_parent_data gcc_parent_data_4[] = { 279 { .index = DT_BI_TCXO }, 280 { .hw = &gcc_gpll7.clkr.hw }, 281 { .hw = &gcc_gpll4.clkr.hw }, 282 { .hw = &gcc_gpll0_out_even.clkr.hw }, 283 }; 284 285 static const struct parent_map gcc_parent_map_5[] = { 286 { P_BI_TCXO, 0 }, 287 { P_GCC_GPLL0_OUT_MAIN, 1 }, 288 { P_GCC_GPLL8_OUT_MAIN, 2 }, 289 { P_GCC_GPLL0_OUT_EVEN, 6 }, 290 }; 291 292 static const struct clk_parent_data gcc_parent_data_5[] = { 293 { .index = DT_BI_TCXO }, 294 { .hw = &gcc_gpll0.clkr.hw }, 295 { .hw = &gcc_gpll8.clkr.hw }, 296 { .hw = &gcc_gpll0_out_even.clkr.hw }, 297 }; 298 299 static const struct parent_map gcc_parent_map_6[] = { 300 { P_BI_TCXO, 0 }, 301 { P_GCC_GPLL0_OUT_MAIN, 1 }, 302 { P_GCC_GPLL7_OUT_MAIN, 2 }, 303 }; 304 305 static const struct clk_parent_data gcc_parent_data_6[] = { 306 { .index = DT_BI_TCXO }, 307 { .hw = &gcc_gpll0.clkr.hw }, 308 { .hw = &gcc_gpll7.clkr.hw }, 309 }; 310 311 static const struct parent_map gcc_parent_map_7[] = { 312 { P_BI_TCXO, 0 }, 313 { P_GCC_GPLL0_OUT_MAIN, 1 }, 314 { P_GCC_GPLL2_OUT_MAIN, 2 }, 315 }; 316 317 static const struct clk_parent_data gcc_parent_data_7[] = { 318 { .index = DT_BI_TCXO }, 319 { .hw = &gcc_gpll0.clkr.hw }, 320 { .hw = &gcc_gpll2.clkr.hw }, 321 }; 322 323 static const struct parent_map gcc_parent_map_8[] = { 324 { P_BI_TCXO, 0 }, 325 { P_GCC_GPLL7_OUT_MAIN, 2 }, 326 { P_RXC0_REF_CLK, 3 }, 327 { P_GCC_GPLL0_OUT_EVEN, 6 }, 328 }; 329 330 static const struct clk_parent_data gcc_parent_data_8[] = { 331 { .index = DT_BI_TCXO }, 332 { .hw = &gcc_gpll7.clkr.hw }, 333 { .index = DT_RXC0_REF_CLK }, 334 { .hw = &gcc_gpll0_out_even.clkr.hw }, 335 }; 336 337 static const struct parent_map gcc_parent_map_9[] = { 338 { P_BI_TCXO, 0 }, 339 { P_GCC_GPLL7_OUT_MAIN, 2 }, 340 { P_RXC1_REF_CLK, 3 }, 341 { P_GCC_GPLL0_OUT_EVEN, 6 }, 342 }; 343 344 static const struct clk_parent_data gcc_parent_data_9[] = { 345 { .index = DT_BI_TCXO }, 346 { .hw = &gcc_gpll7.clkr.hw }, 347 { .index = DT_RXC1_REF_CLK }, 348 { .hw = &gcc_gpll0_out_even.clkr.hw }, 349 }; 350 351 static const struct parent_map gcc_parent_map_15[] = { 352 { P_BI_TCXO, 0 }, 353 { P_GCC_GPLL0_OUT_MAIN, 1 }, 354 { P_GCC_GPLL9_OUT_MAIN, 2 }, 355 { P_GCC_GPLL4_OUT_MAIN, 5 }, 356 { P_GCC_GPLL0_OUT_EVEN, 6 }, 357 }; 358 359 static const struct clk_parent_data gcc_parent_data_15[] = { 360 { .index = DT_BI_TCXO }, 361 { .hw = &gcc_gpll0.clkr.hw }, 362 { .hw = &gcc_gpll9.clkr.hw }, 363 { .hw = &gcc_gpll4.clkr.hw }, 364 { .hw = &gcc_gpll0_out_even.clkr.hw }, 365 }; 366 367 static const struct parent_map gcc_parent_map_16[] = { 368 { P_UFS_CARD_RX_SYMBOL_0_CLK, 0 }, 369 { P_BI_TCXO, 2 }, 370 }; 371 372 static const struct clk_parent_data gcc_parent_data_16[] = { 373 { .index = DT_UFS_CARD_RX_SYMBOL_0_CLK }, 374 { .index = DT_BI_TCXO }, 375 }; 376 377 static const struct parent_map gcc_parent_map_17[] = { 378 { P_UFS_CARD_RX_SYMBOL_1_CLK, 0 }, 379 { P_BI_TCXO, 2 }, 380 }; 381 382 static const struct clk_parent_data gcc_parent_data_17[] = { 383 { .index = DT_UFS_CARD_RX_SYMBOL_1_CLK }, 384 { .index = DT_BI_TCXO }, 385 }; 386 387 static const struct parent_map gcc_parent_map_18[] = { 388 { P_UFS_CARD_TX_SYMBOL_0_CLK, 0 }, 389 { P_BI_TCXO, 2 }, 390 }; 391 392 static const struct clk_parent_data gcc_parent_data_18[] = { 393 { .index = DT_UFS_CARD_TX_SYMBOL_0_CLK }, 394 { .index = DT_BI_TCXO }, 395 }; 396 397 static const struct parent_map gcc_parent_map_19[] = { 398 { P_UFS_PHY_RX_SYMBOL_0_CLK, 0 }, 399 { P_BI_TCXO, 2 }, 400 }; 401 402 static const struct clk_parent_data gcc_parent_data_19[] = { 403 { .index = DT_UFS_PHY_RX_SYMBOL_0_CLK }, 404 { .index = DT_BI_TCXO }, 405 }; 406 407 static const struct parent_map gcc_parent_map_20[] = { 408 { P_UFS_PHY_RX_SYMBOL_1_CLK, 0 }, 409 { P_BI_TCXO, 2 }, 410 }; 411 412 static const struct clk_parent_data gcc_parent_data_20[] = { 413 { .index = DT_UFS_PHY_RX_SYMBOL_1_CLK }, 414 { .index = DT_BI_TCXO }, 415 }; 416 417 static const struct parent_map gcc_parent_map_21[] = { 418 { P_UFS_PHY_TX_SYMBOL_0_CLK, 0 }, 419 { P_BI_TCXO, 2 }, 420 }; 421 422 static const struct clk_parent_data gcc_parent_data_21[] = { 423 { .index = DT_UFS_PHY_TX_SYMBOL_0_CLK }, 424 { .index = DT_BI_TCXO }, 425 }; 426 427 static const struct parent_map gcc_parent_map_22[] = { 428 { P_USB3_PHY_WRAPPER_GCC_USB30_PIPE_CLK, 0 }, 429 { P_BI_TCXO, 2 }, 430 }; 431 432 static const struct clk_parent_data gcc_parent_data_22[] = { 433 { .index = DT_USB3_PHY_WRAPPER_GCC_USB30_PIPE_CLK }, 434 { .index = DT_BI_TCXO }, 435 }; 436 437 static const struct parent_map gcc_parent_map_23[] = { 438 { P_USB3_UNI_PHY_SEC_GCC_USB30_PIPE_CLK, 0 }, 439 { P_BI_TCXO, 2 }, 440 }; 441 442 static const struct clk_parent_data gcc_parent_data_23[] = { 443 { .index = DT_USB3_UNI_PHY_SEC_GCC_USB30_PIPE_CLK }, 444 { .index = DT_BI_TCXO }, 445 }; 446 447 static struct clk_regmap_mux gcc_usb3_prim_phy_pipe_clk_src = { 448 .reg = 0xf060, 449 .shift = 0, 450 .width = 2, 451 .parent_map = gcc_parent_map_22, 452 .clkr = { 453 .hw.init = &(const struct clk_init_data) { 454 .name = "gcc_usb3_prim_phy_pipe_clk_src", 455 .parent_data = gcc_parent_data_22, 456 .num_parents = ARRAY_SIZE(gcc_parent_data_22), 457 .ops = &clk_regmap_mux_closest_ops, 458 }, 459 }, 460 }; 461 462 static struct clk_regmap_mux gcc_usb3_sec_phy_pipe_clk_src = { 463 .reg = 0x10060, 464 .shift = 0, 465 .width = 2, 466 .parent_map = gcc_parent_map_23, 467 .clkr = { 468 .hw.init = &(const struct clk_init_data) { 469 .name = "gcc_usb3_sec_phy_pipe_clk_src", 470 .parent_data = gcc_parent_data_23, 471 .num_parents = ARRAY_SIZE(gcc_parent_data_23), 472 .ops = &clk_regmap_mux_closest_ops, 473 }, 474 }, 475 }; 476 477 static const struct parent_map gcc_parent_map_24[] = { 478 { P_USB3_UNI_PHY_MP_GCC_USB30_PIPE_0_CLK, 0 }, 479 { P_BI_TCXO, 2 }, 480 }; 481 482 static const struct clk_parent_data gcc_parent_data_24[] = { 483 { .index = DT_USB3_UNI_PHY_MP_GCC_USB30_PIPE_0_CLK }, 484 { .index = DT_BI_TCXO }, 485 }; 486 487 static const struct parent_map gcc_parent_map_25[] = { 488 { P_USB3_UNI_PHY_MP_GCC_USB30_PIPE_1_CLK, 0 }, 489 { P_BI_TCXO, 2 }, 490 }; 491 492 static const struct clk_parent_data gcc_parent_data_25[] = { 493 { .index = DT_USB3_UNI_PHY_MP_GCC_USB30_PIPE_1_CLK }, 494 { .index = DT_BI_TCXO }, 495 }; 496 497 static const struct parent_map gcc_parent_map_26[] = { 498 { P_GCC_USB3_PRIM_PHY_PIPE_CLK_SRC, 0 }, 499 { P_USB4_PHY_GCC_USB4RTR_MAX_PIPE_CLK, 1 }, 500 { P_GCC_USB4_PHY_PIPEGMUX_CLK_SRC, 3 }, 501 }; 502 503 static const struct clk_parent_data gcc_parent_data_26[] = { 504 { .hw = &gcc_usb3_prim_phy_pipe_clk_src.clkr.hw }, 505 { .index = DT_USB4_PHY_GCC_USB4RTR_MAX_PIPE_CLK }, 506 { .index = DT_GCC_USB4_PHY_PIPEGMUX_CLK_SRC }, 507 }; 508 509 static const struct parent_map gcc_parent_map_27[] = { 510 { P_GCC_USB3_SEC_PHY_PIPE_CLK_SRC, 0 }, 511 { P_USB4_1_PHY_GCC_USB4RTR_MAX_PIPE_CLK, 1 }, 512 { P_GCC_USB4_1_PHY_PIPEGMUX_CLK_SRC, 3 }, 513 }; 514 515 static const struct clk_parent_data gcc_parent_data_27[] = { 516 { .hw = &gcc_usb3_sec_phy_pipe_clk_src.clkr.hw }, 517 { .index = DT_USB4_1_PHY_GCC_USB4RTR_MAX_PIPE_CLK }, 518 { .index = DT_GCC_USB4_1_PHY_PIPEGMUX_CLK_SRC }, 519 }; 520 521 static const struct parent_map gcc_parent_map_28[] = { 522 { P_GCC_USB4_1_PHY_DP_GMUX_CLK_SRC, 0 }, 523 { P_USB4_1_PHY_GCC_USB4RTR_MAX_PIPE_CLK, 2 }, 524 }; 525 526 static const struct clk_parent_data gcc_parent_data_28[] = { 527 { .index = DT_GCC_USB4_1_PHY_DP_GMUX_CLK_SRC }, 528 { .index = DT_USB4_1_PHY_GCC_USB4RTR_MAX_PIPE_CLK }, 529 }; 530 531 static const struct parent_map gcc_parent_map_29[] = { 532 { P_USB4_1_PHY_GCC_USB4_PCIE_PIPE_CLK, 0 }, 533 { P_BI_TCXO, 2 }, 534 }; 535 536 static const struct clk_parent_data gcc_parent_data_29[] = { 537 { .index = DT_USB4_1_PHY_GCC_USB4_PCIE_PIPE_CLK }, 538 { .index = DT_BI_TCXO }, 539 }; 540 541 static const struct parent_map gcc_parent_map_30[] = { 542 { P_GCC_USB4_1_PHY_SYS_PIPEGMUX_CLK_SRC, 0 }, 543 { P_GCC_USB4_1_PHY_PCIE_PIPE_CLK_SRC, 1 }, 544 }; 545 546 static const struct clk_parent_data gcc_parent_data_30[] = { 547 { .index = DT_GCC_USB4_1_PHY_SYS_PIPEGMUX_CLK_SRC }, 548 { .hw = &gcc_usb4_1_phy_pcie_pipe_clk_src.clkr.hw }, 549 }; 550 551 static struct clk_regmap_mux gcc_usb4_1_phy_pcie_pipegmux_clk_src = { 552 .reg = 0xb80dc, 553 .shift = 0, 554 .width = 1, 555 .parent_map = gcc_parent_map_30, 556 .clkr = { 557 .hw.init = &(const struct clk_init_data) { 558 .name = "gcc_usb4_1_phy_pcie_pipegmux_clk_src", 559 .parent_data = gcc_parent_data_30, 560 .num_parents = ARRAY_SIZE(gcc_parent_data_30), 561 .ops = &clk_regmap_mux_closest_ops, 562 }, 563 }, 564 }; 565 566 static const struct parent_map gcc_parent_map_31[] = { 567 { P_GCC_USB4_1_PHY_PCIE_PIPEGMUX_CLK_SRC, 0 }, 568 { P_USB4_1_PHY_GCC_USB4_PCIE_PIPE_CLK, 2 }, 569 }; 570 571 static const struct clk_parent_data gcc_parent_data_31[] = { 572 { .hw = &gcc_usb4_1_phy_pcie_pipegmux_clk_src.clkr.hw }, 573 { .index = DT_USB4_1_PHY_GCC_USB4_PCIE_PIPE_CLK }, 574 }; 575 576 static const struct parent_map gcc_parent_map_32[] = { 577 { P_QUSB4PHY_1_GCC_USB4_RX0_CLK, 0 }, 578 { P_BI_TCXO, 2 }, 579 }; 580 581 static const struct clk_parent_data gcc_parent_data_32[] = { 582 { .index = DT_QUSB4PHY_1_GCC_USB4_RX0_CLK }, 583 { .index = DT_BI_TCXO }, 584 }; 585 586 static const struct parent_map gcc_parent_map_33[] = { 587 { P_QUSB4PHY_1_GCC_USB4_RX1_CLK, 0 }, 588 { P_BI_TCXO, 2 }, 589 }; 590 591 static const struct clk_parent_data gcc_parent_data_33[] = { 592 { .index = DT_QUSB4PHY_1_GCC_USB4_RX1_CLK }, 593 { .index = DT_BI_TCXO }, 594 }; 595 596 static const struct parent_map gcc_parent_map_34[] = { 597 { P_GCC_USB4_1_PHY_SYS_PIPEGMUX_CLK_SRC, 0 }, 598 { P_USB4_1_PHY_GCC_USB4_PCIE_PIPE_CLK, 2 }, 599 }; 600 601 static const struct clk_parent_data gcc_parent_data_34[] = { 602 { .index = DT_GCC_USB4_1_PHY_SYS_PIPEGMUX_CLK_SRC }, 603 { .index = DT_USB4_1_PHY_GCC_USB4_PCIE_PIPE_CLK }, 604 }; 605 606 static const struct parent_map gcc_parent_map_35[] = { 607 { P_GCC_USB4_PHY_DP_GMUX_CLK_SRC, 0 }, 608 { P_USB4_PHY_GCC_USB4RTR_MAX_PIPE_CLK, 2 }, 609 }; 610 611 static const struct clk_parent_data gcc_parent_data_35[] = { 612 { .index = DT_GCC_USB4_PHY_DP_GMUX_CLK_SRC }, 613 { .index = DT_USB4_PHY_GCC_USB4RTR_MAX_PIPE_CLK }, 614 }; 615 616 static const struct parent_map gcc_parent_map_36[] = { 617 { P_USB4_PHY_GCC_USB4_PCIE_PIPE_CLK, 0 }, 618 { P_BI_TCXO, 2 }, 619 }; 620 621 static const struct clk_parent_data gcc_parent_data_36[] = { 622 { .index = DT_USB4_PHY_GCC_USB4_PCIE_PIPE_CLK }, 623 { .index = DT_BI_TCXO }, 624 }; 625 626 static const struct parent_map gcc_parent_map_37[] = { 627 { P_GCC_USB4_PHY_SYS_PIPEGMUX_CLK_SRC, 0 }, 628 { P_GCC_USB4_PHY_PCIE_PIPE_CLK_SRC, 1 }, 629 }; 630 631 static const struct clk_parent_data gcc_parent_data_37[] = { 632 { .index = DT_GCC_USB4_PHY_SYS_PIPEGMUX_CLK_SRC }, 633 { .hw = &gcc_usb4_phy_pcie_pipe_clk_src.clkr.hw }, 634 }; 635 636 static struct clk_regmap_mux gcc_usb4_phy_pcie_pipegmux_clk_src = { 637 .reg = 0x2a0dc, 638 .shift = 0, 639 .width = 1, 640 .parent_map = gcc_parent_map_37, 641 .clkr = { 642 .hw.init = &(const struct clk_init_data) { 643 .name = "gcc_usb4_phy_pcie_pipegmux_clk_src", 644 .parent_data = gcc_parent_data_37, 645 .num_parents = ARRAY_SIZE(gcc_parent_data_37), 646 .ops = &clk_regmap_mux_closest_ops, 647 }, 648 }, 649 }; 650 651 static const struct parent_map gcc_parent_map_38[] = { 652 { P_GCC_USB4_PHY_PCIE_PIPEGMUX_CLK_SRC, 0 }, 653 { P_USB4_PHY_GCC_USB4_PCIE_PIPE_CLK, 2 }, 654 }; 655 656 static const struct clk_parent_data gcc_parent_data_38[] = { 657 { .hw = &gcc_usb4_phy_pcie_pipegmux_clk_src.clkr.hw }, 658 { .index = DT_USB4_PHY_GCC_USB4_PCIE_PIPE_CLK }, 659 }; 660 661 static const struct parent_map gcc_parent_map_39[] = { 662 { P_QUSB4PHY_GCC_USB4_RX0_CLK, 0 }, 663 { P_BI_TCXO, 2 }, 664 }; 665 666 static const struct clk_parent_data gcc_parent_data_39[] = { 667 { .index = DT_QUSB4PHY_GCC_USB4_RX0_CLK }, 668 { .index = DT_BI_TCXO }, 669 }; 670 671 static const struct parent_map gcc_parent_map_40[] = { 672 { P_QUSB4PHY_GCC_USB4_RX1_CLK, 0 }, 673 { P_BI_TCXO, 2 }, 674 }; 675 676 static const struct clk_parent_data gcc_parent_data_40[] = { 677 { .index = DT_QUSB4PHY_GCC_USB4_RX1_CLK }, 678 { .index = DT_BI_TCXO }, 679 }; 680 681 static const struct parent_map gcc_parent_map_41[] = { 682 { P_GCC_USB4_PHY_SYS_PIPEGMUX_CLK_SRC, 0 }, 683 { P_USB4_PHY_GCC_USB4_PCIE_PIPE_CLK, 2 }, 684 }; 685 686 static const struct clk_parent_data gcc_parent_data_41[] = { 687 { .index = DT_GCC_USB4_PHY_SYS_PIPEGMUX_CLK_SRC }, 688 { .index = DT_USB4_PHY_GCC_USB4_PCIE_PIPE_CLK }, 689 }; 690 691 static struct clk_regmap_phy_mux gcc_pcie_2a_pipe_clk_src = { 692 .reg = 0x9d05c, 693 .clkr = { 694 .hw.init = &(const struct clk_init_data) { 695 .name = "gcc_pcie_2a_pipe_clk_src", 696 .parent_data = &(const struct clk_parent_data){ 697 .index = DT_PCIE_2A_PIPE_CLK, 698 }, 699 .num_parents = 1, 700 .ops = &clk_regmap_phy_mux_ops, 701 }, 702 }, 703 }; 704 705 static struct clk_regmap_phy_mux gcc_pcie_2b_pipe_clk_src = { 706 .reg = 0x9e05c, 707 .clkr = { 708 .hw.init = &(const struct clk_init_data) { 709 .name = "gcc_pcie_2b_pipe_clk_src", 710 .parent_data = &(const struct clk_parent_data){ 711 .index = DT_PCIE_2B_PIPE_CLK, 712 }, 713 .num_parents = 1, 714 .ops = &clk_regmap_phy_mux_ops, 715 }, 716 }, 717 }; 718 719 static struct clk_regmap_phy_mux gcc_pcie_3a_pipe_clk_src = { 720 .reg = 0xa005c, 721 .clkr = { 722 .hw.init = &(const struct clk_init_data) { 723 .name = "gcc_pcie_3a_pipe_clk_src", 724 .parent_data = &(const struct clk_parent_data){ 725 .index = DT_PCIE_3A_PIPE_CLK, 726 }, 727 .num_parents = 1, 728 .ops = &clk_regmap_phy_mux_ops, 729 }, 730 }, 731 }; 732 733 static struct clk_regmap_phy_mux gcc_pcie_3b_pipe_clk_src = { 734 .reg = 0xa205c, 735 .clkr = { 736 .hw.init = &(const struct clk_init_data) { 737 .name = "gcc_pcie_3b_pipe_clk_src", 738 .parent_data = &(const struct clk_parent_data){ 739 .index = DT_PCIE_3B_PIPE_CLK, 740 }, 741 .num_parents = 1, 742 .ops = &clk_regmap_phy_mux_ops, 743 }, 744 }, 745 }; 746 747 static struct clk_regmap_phy_mux gcc_pcie_4_pipe_clk_src = { 748 .reg = 0x6b05c, 749 .clkr = { 750 .hw.init = &(const struct clk_init_data) { 751 .name = "gcc_pcie_4_pipe_clk_src", 752 .parent_data = &(const struct clk_parent_data){ 753 .index = DT_PCIE_4_PIPE_CLK, 754 }, 755 .num_parents = 1, 756 .ops = &clk_regmap_phy_mux_ops, 757 }, 758 }, 759 }; 760 761 static struct clk_regmap_mux gcc_ufs_card_rx_symbol_0_clk_src = { 762 .reg = 0x75058, 763 .shift = 0, 764 .width = 2, 765 .parent_map = gcc_parent_map_16, 766 .clkr = { 767 .hw.init = &(const struct clk_init_data) { 768 .name = "gcc_ufs_card_rx_symbol_0_clk_src", 769 .parent_data = gcc_parent_data_16, 770 .num_parents = ARRAY_SIZE(gcc_parent_data_16), 771 .ops = &clk_regmap_mux_closest_ops, 772 }, 773 }, 774 }; 775 776 static struct clk_regmap_mux gcc_ufs_card_rx_symbol_1_clk_src = { 777 .reg = 0x750c8, 778 .shift = 0, 779 .width = 2, 780 .parent_map = gcc_parent_map_17, 781 .clkr = { 782 .hw.init = &(const struct clk_init_data) { 783 .name = "gcc_ufs_card_rx_symbol_1_clk_src", 784 .parent_data = gcc_parent_data_17, 785 .num_parents = ARRAY_SIZE(gcc_parent_data_17), 786 .ops = &clk_regmap_mux_closest_ops, 787 }, 788 }, 789 }; 790 791 static struct clk_regmap_mux gcc_ufs_card_tx_symbol_0_clk_src = { 792 .reg = 0x75048, 793 .shift = 0, 794 .width = 2, 795 .parent_map = gcc_parent_map_18, 796 .clkr = { 797 .hw.init = &(const struct clk_init_data) { 798 .name = "gcc_ufs_card_tx_symbol_0_clk_src", 799 .parent_data = gcc_parent_data_18, 800 .num_parents = ARRAY_SIZE(gcc_parent_data_18), 801 .ops = &clk_regmap_mux_closest_ops, 802 }, 803 }, 804 }; 805 806 static struct clk_regmap_mux gcc_ufs_phy_rx_symbol_0_clk_src = { 807 .reg = 0x77058, 808 .shift = 0, 809 .width = 2, 810 .parent_map = gcc_parent_map_19, 811 .clkr = { 812 .hw.init = &(const struct clk_init_data) { 813 .name = "gcc_ufs_phy_rx_symbol_0_clk_src", 814 .parent_data = gcc_parent_data_19, 815 .num_parents = ARRAY_SIZE(gcc_parent_data_19), 816 .ops = &clk_regmap_mux_closest_ops, 817 }, 818 }, 819 }; 820 821 static struct clk_regmap_mux gcc_ufs_phy_rx_symbol_1_clk_src = { 822 .reg = 0x770c8, 823 .shift = 0, 824 .width = 2, 825 .parent_map = gcc_parent_map_20, 826 .clkr = { 827 .hw.init = &(const struct clk_init_data) { 828 .name = "gcc_ufs_phy_rx_symbol_1_clk_src", 829 .parent_data = gcc_parent_data_20, 830 .num_parents = ARRAY_SIZE(gcc_parent_data_20), 831 .ops = &clk_regmap_mux_closest_ops, 832 }, 833 }, 834 }; 835 836 static struct clk_regmap_mux gcc_ufs_phy_tx_symbol_0_clk_src = { 837 .reg = 0x77048, 838 .shift = 0, 839 .width = 2, 840 .parent_map = gcc_parent_map_21, 841 .clkr = { 842 .hw.init = &(const struct clk_init_data) { 843 .name = "gcc_ufs_phy_tx_symbol_0_clk_src", 844 .parent_data = gcc_parent_data_21, 845 .num_parents = ARRAY_SIZE(gcc_parent_data_21), 846 .ops = &clk_regmap_mux_closest_ops, 847 }, 848 }, 849 }; 850 851 static struct clk_regmap_mux gcc_usb34_prim_phy_pipe_clk_src = { 852 .reg = 0xf064, 853 .shift = 0, 854 .width = 2, 855 .parent_map = gcc_parent_map_26, 856 .clkr = { 857 .hw.init = &(const struct clk_init_data) { 858 .name = "gcc_usb34_prim_phy_pipe_clk_src", 859 .parent_data = gcc_parent_data_26, 860 .num_parents = ARRAY_SIZE(gcc_parent_data_26), 861 .ops = &clk_regmap_mux_closest_ops, 862 }, 863 }, 864 }; 865 866 static struct clk_regmap_mux gcc_usb34_sec_phy_pipe_clk_src = { 867 .reg = 0x10064, 868 .shift = 0, 869 .width = 2, 870 .parent_map = gcc_parent_map_27, 871 .clkr = { 872 .hw.init = &(const struct clk_init_data) { 873 .name = "gcc_usb34_sec_phy_pipe_clk_src", 874 .parent_data = gcc_parent_data_27, 875 .num_parents = ARRAY_SIZE(gcc_parent_data_27), 876 .ops = &clk_regmap_mux_closest_ops, 877 }, 878 }, 879 }; 880 881 static struct clk_regmap_mux gcc_usb3_mp_phy_pipe_0_clk_src = { 882 .reg = 0xab060, 883 .shift = 0, 884 .width = 2, 885 .parent_map = gcc_parent_map_24, 886 .clkr = { 887 .hw.init = &(const struct clk_init_data) { 888 .name = "gcc_usb3_mp_phy_pipe_0_clk_src", 889 .parent_data = gcc_parent_data_24, 890 .num_parents = ARRAY_SIZE(gcc_parent_data_24), 891 .ops = &clk_regmap_mux_closest_ops, 892 }, 893 }, 894 }; 895 896 static struct clk_regmap_mux gcc_usb3_mp_phy_pipe_1_clk_src = { 897 .reg = 0xab068, 898 .shift = 0, 899 .width = 2, 900 .parent_map = gcc_parent_map_25, 901 .clkr = { 902 .hw.init = &(const struct clk_init_data) { 903 .name = "gcc_usb3_mp_phy_pipe_1_clk_src", 904 .parent_data = gcc_parent_data_25, 905 .num_parents = ARRAY_SIZE(gcc_parent_data_25), 906 .ops = &clk_regmap_mux_closest_ops, 907 }, 908 }, 909 }; 910 911 static struct clk_regmap_mux gcc_usb4_1_phy_dp_clk_src = { 912 .reg = 0xb8050, 913 .shift = 0, 914 .width = 2, 915 .parent_map = gcc_parent_map_28, 916 .clkr = { 917 .hw.init = &(const struct clk_init_data) { 918 .name = "gcc_usb4_1_phy_dp_clk_src", 919 .parent_data = gcc_parent_data_28, 920 .num_parents = ARRAY_SIZE(gcc_parent_data_28), 921 .ops = &clk_regmap_mux_closest_ops, 922 }, 923 }, 924 }; 925 926 static struct clk_regmap_mux gcc_usb4_1_phy_p2rr2p_pipe_clk_src = { 927 .reg = 0xb80b0, 928 .shift = 0, 929 .width = 2, 930 .parent_map = gcc_parent_map_29, 931 .clkr = { 932 .hw.init = &(const struct clk_init_data) { 933 .name = "gcc_usb4_1_phy_p2rr2p_pipe_clk_src", 934 .parent_data = gcc_parent_data_29, 935 .num_parents = ARRAY_SIZE(gcc_parent_data_29), 936 .ops = &clk_regmap_mux_closest_ops, 937 }, 938 }, 939 }; 940 941 static struct clk_regmap_mux gcc_usb4_1_phy_pcie_pipe_mux_clk_src = { 942 .reg = 0xb80e0, 943 .shift = 0, 944 .width = 2, 945 .parent_map = gcc_parent_map_31, 946 .clkr = { 947 .hw.init = &(const struct clk_init_data) { 948 .name = "gcc_usb4_1_phy_pcie_pipe_mux_clk_src", 949 .parent_data = gcc_parent_data_31, 950 .num_parents = ARRAY_SIZE(gcc_parent_data_31), 951 .ops = &clk_regmap_mux_closest_ops, 952 }, 953 }, 954 }; 955 956 static struct clk_regmap_mux gcc_usb4_1_phy_rx0_clk_src = { 957 .reg = 0xb8090, 958 .shift = 0, 959 .width = 2, 960 .parent_map = gcc_parent_map_32, 961 .clkr = { 962 .hw.init = &(const struct clk_init_data) { 963 .name = "gcc_usb4_1_phy_rx0_clk_src", 964 .parent_data = gcc_parent_data_32, 965 .num_parents = ARRAY_SIZE(gcc_parent_data_32), 966 .ops = &clk_regmap_mux_closest_ops, 967 }, 968 }, 969 }; 970 971 static struct clk_regmap_mux gcc_usb4_1_phy_rx1_clk_src = { 972 .reg = 0xb809c, 973 .shift = 0, 974 .width = 2, 975 .parent_map = gcc_parent_map_33, 976 .clkr = { 977 .hw.init = &(const struct clk_init_data) { 978 .name = "gcc_usb4_1_phy_rx1_clk_src", 979 .parent_data = gcc_parent_data_33, 980 .num_parents = ARRAY_SIZE(gcc_parent_data_33), 981 .ops = &clk_regmap_mux_closest_ops, 982 }, 983 }, 984 }; 985 986 static struct clk_regmap_mux gcc_usb4_1_phy_sys_clk_src = { 987 .reg = 0xb80c0, 988 .shift = 0, 989 .width = 2, 990 .parent_map = gcc_parent_map_34, 991 .clkr = { 992 .hw.init = &(const struct clk_init_data) { 993 .name = "gcc_usb4_1_phy_sys_clk_src", 994 .parent_data = gcc_parent_data_34, 995 .num_parents = ARRAY_SIZE(gcc_parent_data_34), 996 .ops = &clk_regmap_mux_closest_ops, 997 }, 998 }, 999 }; 1000 1001 static struct clk_regmap_mux gcc_usb4_phy_dp_clk_src = { 1002 .reg = 0x2a050, 1003 .shift = 0, 1004 .width = 2, 1005 .parent_map = gcc_parent_map_35, 1006 .clkr = { 1007 .hw.init = &(const struct clk_init_data) { 1008 .name = "gcc_usb4_phy_dp_clk_src", 1009 .parent_data = gcc_parent_data_35, 1010 .num_parents = ARRAY_SIZE(gcc_parent_data_35), 1011 .ops = &clk_regmap_mux_closest_ops, 1012 }, 1013 }, 1014 }; 1015 1016 static struct clk_regmap_mux gcc_usb4_phy_p2rr2p_pipe_clk_src = { 1017 .reg = 0x2a0b0, 1018 .shift = 0, 1019 .width = 2, 1020 .parent_map = gcc_parent_map_36, 1021 .clkr = { 1022 .hw.init = &(const struct clk_init_data) { 1023 .name = "gcc_usb4_phy_p2rr2p_pipe_clk_src", 1024 .parent_data = gcc_parent_data_36, 1025 .num_parents = ARRAY_SIZE(gcc_parent_data_36), 1026 .ops = &clk_regmap_mux_closest_ops, 1027 }, 1028 }, 1029 }; 1030 1031 static struct clk_regmap_mux gcc_usb4_phy_pcie_pipe_mux_clk_src = { 1032 .reg = 0x2a0e0, 1033 .shift = 0, 1034 .width = 2, 1035 .parent_map = gcc_parent_map_38, 1036 .clkr = { 1037 .hw.init = &(const struct clk_init_data) { 1038 .name = "gcc_usb4_phy_pcie_pipe_mux_clk_src", 1039 .parent_data = gcc_parent_data_38, 1040 .num_parents = ARRAY_SIZE(gcc_parent_data_38), 1041 .ops = &clk_regmap_mux_closest_ops, 1042 }, 1043 }, 1044 }; 1045 1046 static struct clk_regmap_mux gcc_usb4_phy_rx0_clk_src = { 1047 .reg = 0x2a090, 1048 .shift = 0, 1049 .width = 2, 1050 .parent_map = gcc_parent_map_39, 1051 .clkr = { 1052 .hw.init = &(const struct clk_init_data) { 1053 .name = "gcc_usb4_phy_rx0_clk_src", 1054 .parent_data = gcc_parent_data_39, 1055 .num_parents = ARRAY_SIZE(gcc_parent_data_39), 1056 .ops = &clk_regmap_mux_closest_ops, 1057 }, 1058 }, 1059 }; 1060 1061 static struct clk_regmap_mux gcc_usb4_phy_rx1_clk_src = { 1062 .reg = 0x2a09c, 1063 .shift = 0, 1064 .width = 2, 1065 .parent_map = gcc_parent_map_40, 1066 .clkr = { 1067 .hw.init = &(const struct clk_init_data) { 1068 .name = "gcc_usb4_phy_rx1_clk_src", 1069 .parent_data = gcc_parent_data_40, 1070 .num_parents = ARRAY_SIZE(gcc_parent_data_40), 1071 .ops = &clk_regmap_mux_closest_ops, 1072 }, 1073 }, 1074 }; 1075 1076 static struct clk_regmap_mux gcc_usb4_phy_sys_clk_src = { 1077 .reg = 0x2a0c0, 1078 .shift = 0, 1079 .width = 2, 1080 .parent_map = gcc_parent_map_41, 1081 .clkr = { 1082 .hw.init = &(const struct clk_init_data) { 1083 .name = "gcc_usb4_phy_sys_clk_src", 1084 .parent_data = gcc_parent_data_41, 1085 .num_parents = ARRAY_SIZE(gcc_parent_data_41), 1086 .ops = &clk_regmap_mux_closest_ops, 1087 }, 1088 }, 1089 }; 1090 1091 static const struct freq_tbl ftbl_gcc_emac0_ptp_clk_src[] = { 1092 F(75000000, P_GCC_GPLL0_OUT_EVEN, 4, 0, 0), 1093 F(125000000, P_GCC_GPLL7_OUT_MAIN, 4, 0, 0), 1094 F(230400000, P_GCC_GPLL4_OUT_MAIN, 3.5, 0, 0), 1095 { } 1096 }; 1097 1098 static struct clk_rcg2 gcc_emac0_ptp_clk_src = { 1099 .cmd_rcgr = 0xaa020, 1100 .mnd_width = 0, 1101 .hid_width = 5, 1102 .parent_map = gcc_parent_map_4, 1103 .freq_tbl = ftbl_gcc_emac0_ptp_clk_src, 1104 .clkr.hw.init = &(const struct clk_init_data) { 1105 .name = "gcc_emac0_ptp_clk_src", 1106 .parent_data = gcc_parent_data_4, 1107 .num_parents = ARRAY_SIZE(gcc_parent_data_4), 1108 .ops = &clk_rcg2_shared_ops, 1109 }, 1110 }; 1111 1112 static const struct freq_tbl ftbl_gcc_emac0_rgmii_clk_src[] = { 1113 F(50000000, P_GCC_GPLL0_OUT_EVEN, 6, 0, 0), 1114 F(125000000, P_GCC_GPLL7_OUT_MAIN, 4, 0, 0), 1115 F(250000000, P_GCC_GPLL7_OUT_MAIN, 2, 0, 0), 1116 { } 1117 }; 1118 1119 static struct clk_rcg2 gcc_emac0_rgmii_clk_src = { 1120 .cmd_rcgr = 0xaa040, 1121 .mnd_width = 8, 1122 .hid_width = 5, 1123 .parent_map = gcc_parent_map_8, 1124 .freq_tbl = ftbl_gcc_emac0_rgmii_clk_src, 1125 .clkr.hw.init = &(const struct clk_init_data) { 1126 .name = "gcc_emac0_rgmii_clk_src", 1127 .parent_data = gcc_parent_data_8, 1128 .num_parents = ARRAY_SIZE(gcc_parent_data_8), 1129 .ops = &clk_rcg2_shared_ops, 1130 }, 1131 }; 1132 1133 static struct clk_rcg2 gcc_emac1_ptp_clk_src = { 1134 .cmd_rcgr = 0xba020, 1135 .mnd_width = 0, 1136 .hid_width = 5, 1137 .parent_map = gcc_parent_map_4, 1138 .freq_tbl = ftbl_gcc_emac0_ptp_clk_src, 1139 .clkr.hw.init = &(const struct clk_init_data) { 1140 .name = "gcc_emac1_ptp_clk_src", 1141 .parent_data = gcc_parent_data_4, 1142 .num_parents = ARRAY_SIZE(gcc_parent_data_4), 1143 .ops = &clk_rcg2_shared_ops, 1144 }, 1145 }; 1146 1147 static struct clk_rcg2 gcc_emac1_rgmii_clk_src = { 1148 .cmd_rcgr = 0xba040, 1149 .mnd_width = 8, 1150 .hid_width = 5, 1151 .parent_map = gcc_parent_map_9, 1152 .freq_tbl = ftbl_gcc_emac0_rgmii_clk_src, 1153 .clkr.hw.init = &(const struct clk_init_data) { 1154 .name = "gcc_emac1_rgmii_clk_src", 1155 .parent_data = gcc_parent_data_9, 1156 .num_parents = ARRAY_SIZE(gcc_parent_data_9), 1157 .ops = &clk_rcg2_shared_ops, 1158 }, 1159 }; 1160 1161 static const struct freq_tbl ftbl_gcc_gp1_clk_src[] = { 1162 F(50000000, P_GCC_GPLL0_OUT_EVEN, 6, 0, 0), 1163 F(100000000, P_GCC_GPLL0_OUT_MAIN, 6, 0, 0), 1164 F(200000000, P_GCC_GPLL0_OUT_MAIN, 3, 0, 0), 1165 { } 1166 }; 1167 1168 static struct clk_rcg2 gcc_gp1_clk_src = { 1169 .cmd_rcgr = 0x64004, 1170 .mnd_width = 16, 1171 .hid_width = 5, 1172 .parent_map = gcc_parent_map_2, 1173 .freq_tbl = ftbl_gcc_gp1_clk_src, 1174 .clkr.hw.init = &(const struct clk_init_data) { 1175 .name = "gcc_gp1_clk_src", 1176 .parent_data = gcc_parent_data_2, 1177 .num_parents = ARRAY_SIZE(gcc_parent_data_2), 1178 .ops = &clk_rcg2_shared_ops, 1179 }, 1180 }; 1181 1182 static struct clk_rcg2 gcc_gp2_clk_src = { 1183 .cmd_rcgr = 0x65004, 1184 .mnd_width = 16, 1185 .hid_width = 5, 1186 .parent_map = gcc_parent_map_2, 1187 .freq_tbl = ftbl_gcc_gp1_clk_src, 1188 .clkr.hw.init = &(const struct clk_init_data) { 1189 .name = "gcc_gp2_clk_src", 1190 .parent_data = gcc_parent_data_2, 1191 .num_parents = ARRAY_SIZE(gcc_parent_data_2), 1192 .ops = &clk_rcg2_shared_ops, 1193 }, 1194 }; 1195 1196 static struct clk_rcg2 gcc_gp3_clk_src = { 1197 .cmd_rcgr = 0x66004, 1198 .mnd_width = 16, 1199 .hid_width = 5, 1200 .parent_map = gcc_parent_map_2, 1201 .freq_tbl = ftbl_gcc_gp1_clk_src, 1202 .clkr.hw.init = &(const struct clk_init_data) { 1203 .name = "gcc_gp3_clk_src", 1204 .parent_data = gcc_parent_data_2, 1205 .num_parents = ARRAY_SIZE(gcc_parent_data_2), 1206 .ops = &clk_rcg2_shared_ops, 1207 }, 1208 }; 1209 1210 static struct clk_rcg2 gcc_gp4_clk_src = { 1211 .cmd_rcgr = 0xc2004, 1212 .mnd_width = 16, 1213 .hid_width = 5, 1214 .parent_map = gcc_parent_map_2, 1215 .freq_tbl = ftbl_gcc_gp1_clk_src, 1216 .clkr.hw.init = &(const struct clk_init_data) { 1217 .name = "gcc_gp4_clk_src", 1218 .parent_data = gcc_parent_data_2, 1219 .num_parents = ARRAY_SIZE(gcc_parent_data_2), 1220 .ops = &clk_rcg2_shared_ops, 1221 }, 1222 }; 1223 1224 static struct clk_rcg2 gcc_gp5_clk_src = { 1225 .cmd_rcgr = 0xc3004, 1226 .mnd_width = 16, 1227 .hid_width = 5, 1228 .parent_map = gcc_parent_map_2, 1229 .freq_tbl = ftbl_gcc_gp1_clk_src, 1230 .clkr.hw.init = &(const struct clk_init_data) { 1231 .name = "gcc_gp5_clk_src", 1232 .parent_data = gcc_parent_data_2, 1233 .num_parents = ARRAY_SIZE(gcc_parent_data_2), 1234 .ops = &clk_rcg2_shared_ops, 1235 }, 1236 }; 1237 1238 static const struct freq_tbl ftbl_gcc_pcie_0_aux_clk_src[] = { 1239 F(9600000, P_BI_TCXO, 2, 0, 0), 1240 F(19200000, P_BI_TCXO, 1, 0, 0), 1241 { } 1242 }; 1243 1244 static struct clk_rcg2 gcc_pcie_0_aux_clk_src = { 1245 .cmd_rcgr = 0xa4054, 1246 .mnd_width = 16, 1247 .hid_width = 5, 1248 .parent_map = gcc_parent_map_1, 1249 .freq_tbl = ftbl_gcc_pcie_0_aux_clk_src, 1250 .clkr.hw.init = &(const struct clk_init_data) { 1251 .name = "gcc_pcie_0_aux_clk_src", 1252 .parent_data = gcc_parent_data_1, 1253 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 1254 .ops = &clk_rcg2_shared_ops, 1255 }, 1256 }; 1257 1258 static const struct freq_tbl ftbl_gcc_pcie_0_phy_rchng_clk_src[] = { 1259 F(100000000, P_GCC_GPLL0_OUT_EVEN, 3, 0, 0), 1260 { } 1261 }; 1262 1263 static struct clk_rcg2 gcc_pcie_0_phy_rchng_clk_src = { 1264 .cmd_rcgr = 0xa403c, 1265 .mnd_width = 0, 1266 .hid_width = 5, 1267 .parent_map = gcc_parent_map_0, 1268 .freq_tbl = ftbl_gcc_pcie_0_phy_rchng_clk_src, 1269 .clkr.hw.init = &(const struct clk_init_data) { 1270 .name = "gcc_pcie_0_phy_rchng_clk_src", 1271 .parent_data = gcc_parent_data_0, 1272 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1273 .ops = &clk_rcg2_shared_ops, 1274 }, 1275 }; 1276 1277 static const struct freq_tbl ftbl_gcc_pcie_1_aux_clk_src[] = { 1278 F(19200000, P_BI_TCXO, 1, 0, 0), 1279 { } 1280 }; 1281 1282 static struct clk_rcg2 gcc_pcie_1_aux_clk_src = { 1283 .cmd_rcgr = 0x8d054, 1284 .mnd_width = 16, 1285 .hid_width = 5, 1286 .parent_map = gcc_parent_map_1, 1287 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 1288 .clkr.hw.init = &(const struct clk_init_data) { 1289 .name = "gcc_pcie_1_aux_clk_src", 1290 .parent_data = gcc_parent_data_1, 1291 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 1292 .ops = &clk_rcg2_shared_ops, 1293 }, 1294 }; 1295 1296 static struct clk_rcg2 gcc_pcie_1_phy_rchng_clk_src = { 1297 .cmd_rcgr = 0x8d03c, 1298 .mnd_width = 0, 1299 .hid_width = 5, 1300 .parent_map = gcc_parent_map_0, 1301 .freq_tbl = ftbl_gcc_pcie_0_phy_rchng_clk_src, 1302 .clkr.hw.init = &(const struct clk_init_data) { 1303 .name = "gcc_pcie_1_phy_rchng_clk_src", 1304 .parent_data = gcc_parent_data_0, 1305 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1306 .ops = &clk_rcg2_shared_ops, 1307 }, 1308 }; 1309 1310 static struct clk_rcg2 gcc_pcie_2a_aux_clk_src = { 1311 .cmd_rcgr = 0x9d064, 1312 .mnd_width = 16, 1313 .hid_width = 5, 1314 .parent_map = gcc_parent_map_1, 1315 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 1316 .clkr.hw.init = &(const struct clk_init_data) { 1317 .name = "gcc_pcie_2a_aux_clk_src", 1318 .parent_data = gcc_parent_data_1, 1319 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 1320 .ops = &clk_rcg2_shared_ops, 1321 }, 1322 }; 1323 1324 static struct clk_rcg2 gcc_pcie_2a_phy_rchng_clk_src = { 1325 .cmd_rcgr = 0x9d044, 1326 .mnd_width = 0, 1327 .hid_width = 5, 1328 .parent_map = gcc_parent_map_0, 1329 .freq_tbl = ftbl_gcc_pcie_0_phy_rchng_clk_src, 1330 .clkr.hw.init = &(const struct clk_init_data) { 1331 .name = "gcc_pcie_2a_phy_rchng_clk_src", 1332 .parent_data = gcc_parent_data_0, 1333 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1334 .ops = &clk_rcg2_shared_ops, 1335 }, 1336 }; 1337 1338 static struct clk_rcg2 gcc_pcie_2b_aux_clk_src = { 1339 .cmd_rcgr = 0x9e064, 1340 .mnd_width = 16, 1341 .hid_width = 5, 1342 .parent_map = gcc_parent_map_1, 1343 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 1344 .clkr.hw.init = &(const struct clk_init_data) { 1345 .name = "gcc_pcie_2b_aux_clk_src", 1346 .parent_data = gcc_parent_data_1, 1347 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 1348 .ops = &clk_rcg2_shared_ops, 1349 }, 1350 }; 1351 1352 static struct clk_rcg2 gcc_pcie_2b_phy_rchng_clk_src = { 1353 .cmd_rcgr = 0x9e044, 1354 .mnd_width = 0, 1355 .hid_width = 5, 1356 .parent_map = gcc_parent_map_0, 1357 .freq_tbl = ftbl_gcc_pcie_0_phy_rchng_clk_src, 1358 .clkr.hw.init = &(const struct clk_init_data) { 1359 .name = "gcc_pcie_2b_phy_rchng_clk_src", 1360 .parent_data = gcc_parent_data_0, 1361 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1362 .ops = &clk_rcg2_shared_ops, 1363 }, 1364 }; 1365 1366 static struct clk_rcg2 gcc_pcie_3a_aux_clk_src = { 1367 .cmd_rcgr = 0xa0064, 1368 .mnd_width = 16, 1369 .hid_width = 5, 1370 .parent_map = gcc_parent_map_1, 1371 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 1372 .clkr.hw.init = &(const struct clk_init_data) { 1373 .name = "gcc_pcie_3a_aux_clk_src", 1374 .parent_data = gcc_parent_data_1, 1375 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 1376 .ops = &clk_rcg2_shared_ops, 1377 }, 1378 }; 1379 1380 static struct clk_rcg2 gcc_pcie_3a_phy_rchng_clk_src = { 1381 .cmd_rcgr = 0xa0044, 1382 .mnd_width = 0, 1383 .hid_width = 5, 1384 .parent_map = gcc_parent_map_0, 1385 .freq_tbl = ftbl_gcc_pcie_0_phy_rchng_clk_src, 1386 .clkr.hw.init = &(const struct clk_init_data) { 1387 .name = "gcc_pcie_3a_phy_rchng_clk_src", 1388 .parent_data = gcc_parent_data_0, 1389 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1390 .ops = &clk_rcg2_shared_ops, 1391 }, 1392 }; 1393 1394 static struct clk_rcg2 gcc_pcie_3b_aux_clk_src = { 1395 .cmd_rcgr = 0xa2064, 1396 .mnd_width = 16, 1397 .hid_width = 5, 1398 .parent_map = gcc_parent_map_1, 1399 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 1400 .clkr.hw.init = &(const struct clk_init_data) { 1401 .name = "gcc_pcie_3b_aux_clk_src", 1402 .parent_data = gcc_parent_data_1, 1403 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 1404 .ops = &clk_rcg2_shared_ops, 1405 }, 1406 }; 1407 1408 static struct clk_rcg2 gcc_pcie_3b_phy_rchng_clk_src = { 1409 .cmd_rcgr = 0xa2044, 1410 .mnd_width = 0, 1411 .hid_width = 5, 1412 .parent_map = gcc_parent_map_0, 1413 .freq_tbl = ftbl_gcc_pcie_0_phy_rchng_clk_src, 1414 .clkr.hw.init = &(const struct clk_init_data) { 1415 .name = "gcc_pcie_3b_phy_rchng_clk_src", 1416 .parent_data = gcc_parent_data_0, 1417 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1418 .ops = &clk_rcg2_shared_ops, 1419 }, 1420 }; 1421 1422 static struct clk_rcg2 gcc_pcie_4_aux_clk_src = { 1423 .cmd_rcgr = 0x6b064, 1424 .mnd_width = 16, 1425 .hid_width = 5, 1426 .parent_map = gcc_parent_map_1, 1427 .freq_tbl = ftbl_gcc_pcie_0_aux_clk_src, 1428 .clkr.hw.init = &(const struct clk_init_data) { 1429 .name = "gcc_pcie_4_aux_clk_src", 1430 .parent_data = gcc_parent_data_1, 1431 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 1432 .ops = &clk_rcg2_shared_ops, 1433 }, 1434 }; 1435 1436 static struct clk_rcg2 gcc_pcie_4_phy_rchng_clk_src = { 1437 .cmd_rcgr = 0x6b044, 1438 .mnd_width = 0, 1439 .hid_width = 5, 1440 .parent_map = gcc_parent_map_0, 1441 .freq_tbl = ftbl_gcc_pcie_0_phy_rchng_clk_src, 1442 .clkr.hw.init = &(const struct clk_init_data) { 1443 .name = "gcc_pcie_4_phy_rchng_clk_src", 1444 .parent_data = gcc_parent_data_0, 1445 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1446 .ops = &clk_rcg2_shared_ops, 1447 }, 1448 }; 1449 1450 static struct clk_rcg2 gcc_pcie_rscc_xo_clk_src = { 1451 .cmd_rcgr = 0xae00c, 1452 .mnd_width = 0, 1453 .hid_width = 5, 1454 .parent_map = gcc_parent_map_3, 1455 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 1456 .clkr.hw.init = &(const struct clk_init_data) { 1457 .name = "gcc_pcie_rscc_xo_clk_src", 1458 .parent_data = gcc_parent_data_3, 1459 .num_parents = ARRAY_SIZE(gcc_parent_data_3), 1460 .ops = &clk_rcg2_shared_ops, 1461 }, 1462 }; 1463 1464 static const struct freq_tbl ftbl_gcc_pdm2_clk_src[] = { 1465 F(60000000, P_GCC_GPLL0_OUT_EVEN, 5, 0, 0), 1466 { } 1467 }; 1468 1469 static struct clk_rcg2 gcc_pdm2_clk_src = { 1470 .cmd_rcgr = 0x33010, 1471 .mnd_width = 0, 1472 .hid_width = 5, 1473 .parent_map = gcc_parent_map_0, 1474 .freq_tbl = ftbl_gcc_pdm2_clk_src, 1475 .clkr.hw.init = &(const struct clk_init_data) { 1476 .name = "gcc_pdm2_clk_src", 1477 .parent_data = gcc_parent_data_0, 1478 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1479 .ops = &clk_rcg2_shared_ops, 1480 }, 1481 }; 1482 1483 static const struct freq_tbl ftbl_gcc_qupv3_wrap0_s0_clk_src[] = { 1484 F(7372800, P_GCC_GPLL0_OUT_EVEN, 1, 384, 15625), 1485 F(14745600, P_GCC_GPLL0_OUT_EVEN, 1, 768, 15625), 1486 F(19200000, P_BI_TCXO, 1, 0, 0), 1487 F(29491200, P_GCC_GPLL0_OUT_EVEN, 1, 1536, 15625), 1488 F(32000000, P_GCC_GPLL0_OUT_EVEN, 1, 8, 75), 1489 F(48000000, P_GCC_GPLL0_OUT_EVEN, 1, 4, 25), 1490 F(64000000, P_GCC_GPLL0_OUT_EVEN, 1, 16, 75), 1491 F(75000000, P_GCC_GPLL0_OUT_EVEN, 4, 0, 0), 1492 F(80000000, P_GCC_GPLL0_OUT_EVEN, 1, 4, 15), 1493 F(96000000, P_GCC_GPLL0_OUT_EVEN, 1, 8, 25), 1494 F(100000000, P_GCC_GPLL0_OUT_MAIN, 6, 0, 0), 1495 { } 1496 }; 1497 1498 static struct clk_init_data gcc_qupv3_wrap0_s0_clk_src_init = { 1499 .name = "gcc_qupv3_wrap0_s0_clk_src", 1500 .parent_data = gcc_parent_data_0, 1501 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1502 .flags = CLK_SET_RATE_PARENT, 1503 .ops = &clk_rcg2_ops, 1504 }; 1505 1506 static struct clk_rcg2 gcc_qupv3_wrap0_s0_clk_src = { 1507 .cmd_rcgr = 0x17148, 1508 .mnd_width = 16, 1509 .hid_width = 5, 1510 .parent_map = gcc_parent_map_0, 1511 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1512 .clkr.hw.init = &gcc_qupv3_wrap0_s0_clk_src_init, 1513 }; 1514 1515 static struct clk_init_data gcc_qupv3_wrap0_s1_clk_src_init = { 1516 .name = "gcc_qupv3_wrap0_s1_clk_src", 1517 .parent_data = gcc_parent_data_0, 1518 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1519 .flags = CLK_SET_RATE_PARENT, 1520 .ops = &clk_rcg2_ops, 1521 }; 1522 1523 static struct clk_rcg2 gcc_qupv3_wrap0_s1_clk_src = { 1524 .cmd_rcgr = 0x17278, 1525 .mnd_width = 16, 1526 .hid_width = 5, 1527 .parent_map = gcc_parent_map_0, 1528 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1529 .clkr.hw.init = &gcc_qupv3_wrap0_s1_clk_src_init, 1530 }; 1531 1532 static struct clk_init_data gcc_qupv3_wrap0_s2_clk_src_init = { 1533 .name = "gcc_qupv3_wrap0_s2_clk_src", 1534 .parent_data = gcc_parent_data_0, 1535 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1536 .flags = CLK_SET_RATE_PARENT, 1537 .ops = &clk_rcg2_ops, 1538 }; 1539 1540 static struct clk_rcg2 gcc_qupv3_wrap0_s2_clk_src = { 1541 .cmd_rcgr = 0x173a8, 1542 .mnd_width = 16, 1543 .hid_width = 5, 1544 .parent_map = gcc_parent_map_0, 1545 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1546 .clkr.hw.init = &gcc_qupv3_wrap0_s2_clk_src_init, 1547 }; 1548 1549 static struct clk_init_data gcc_qupv3_wrap0_s3_clk_src_init = { 1550 .name = "gcc_qupv3_wrap0_s3_clk_src", 1551 .parent_data = gcc_parent_data_0, 1552 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1553 .flags = CLK_SET_RATE_PARENT, 1554 .ops = &clk_rcg2_ops, 1555 }; 1556 1557 static struct clk_rcg2 gcc_qupv3_wrap0_s3_clk_src = { 1558 .cmd_rcgr = 0x174d8, 1559 .mnd_width = 16, 1560 .hid_width = 5, 1561 .parent_map = gcc_parent_map_0, 1562 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1563 .clkr.hw.init = &gcc_qupv3_wrap0_s3_clk_src_init, 1564 }; 1565 1566 static struct clk_init_data gcc_qupv3_wrap0_s4_clk_src_init = { 1567 .name = "gcc_qupv3_wrap0_s4_clk_src", 1568 .parent_data = gcc_parent_data_0, 1569 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1570 .flags = CLK_SET_RATE_PARENT, 1571 .ops = &clk_rcg2_ops, 1572 }; 1573 1574 static struct clk_rcg2 gcc_qupv3_wrap0_s4_clk_src = { 1575 .cmd_rcgr = 0x17608, 1576 .mnd_width = 16, 1577 .hid_width = 5, 1578 .parent_map = gcc_parent_map_0, 1579 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1580 .clkr.hw.init = &gcc_qupv3_wrap0_s4_clk_src_init, 1581 }; 1582 1583 static struct clk_init_data gcc_qupv3_wrap0_s5_clk_src_init = { 1584 .name = "gcc_qupv3_wrap0_s5_clk_src", 1585 .parent_data = gcc_parent_data_0, 1586 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1587 .flags = CLK_SET_RATE_PARENT, 1588 .ops = &clk_rcg2_ops, 1589 }; 1590 1591 static struct clk_rcg2 gcc_qupv3_wrap0_s5_clk_src = { 1592 .cmd_rcgr = 0x17738, 1593 .mnd_width = 16, 1594 .hid_width = 5, 1595 .parent_map = gcc_parent_map_0, 1596 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1597 .clkr.hw.init = &gcc_qupv3_wrap0_s5_clk_src_init, 1598 }; 1599 1600 static const struct freq_tbl ftbl_gcc_qupv3_wrap0_s6_clk_src[] = { 1601 F(7372800, P_GCC_GPLL0_OUT_EVEN, 1, 384, 15625), 1602 F(14745600, P_GCC_GPLL0_OUT_EVEN, 1, 768, 15625), 1603 F(19200000, P_BI_TCXO, 1, 0, 0), 1604 F(29491200, P_GCC_GPLL0_OUT_EVEN, 1, 1536, 15625), 1605 F(32000000, P_GCC_GPLL0_OUT_EVEN, 1, 8, 75), 1606 F(48000000, P_GCC_GPLL0_OUT_EVEN, 1, 4, 25), 1607 F(64000000, P_GCC_GPLL0_OUT_EVEN, 1, 16, 75), 1608 F(75000000, P_GCC_GPLL0_OUT_EVEN, 4, 0, 0), 1609 F(80000000, P_GCC_GPLL0_OUT_EVEN, 1, 4, 15), 1610 F(96000000, P_GCC_GPLL0_OUT_EVEN, 1, 8, 25), 1611 F(120000000, P_GCC_GPLL0_OUT_MAIN, 5, 0, 0), 1612 { } 1613 }; 1614 1615 static struct clk_init_data gcc_qupv3_wrap0_s6_clk_src_init = { 1616 .name = "gcc_qupv3_wrap0_s6_clk_src", 1617 .parent_data = gcc_parent_data_0, 1618 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1619 .flags = CLK_SET_RATE_PARENT, 1620 .ops = &clk_rcg2_ops, 1621 }; 1622 1623 static struct clk_rcg2 gcc_qupv3_wrap0_s6_clk_src = { 1624 .cmd_rcgr = 0x17868, 1625 .mnd_width = 16, 1626 .hid_width = 5, 1627 .parent_map = gcc_parent_map_0, 1628 .freq_tbl = ftbl_gcc_qupv3_wrap0_s6_clk_src, 1629 .clkr.hw.init = &gcc_qupv3_wrap0_s6_clk_src_init, 1630 }; 1631 1632 static struct clk_init_data gcc_qupv3_wrap0_s7_clk_src_init = { 1633 .name = "gcc_qupv3_wrap0_s7_clk_src", 1634 .parent_data = gcc_parent_data_0, 1635 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1636 .flags = CLK_SET_RATE_PARENT, 1637 .ops = &clk_rcg2_ops, 1638 }; 1639 1640 static struct clk_rcg2 gcc_qupv3_wrap0_s7_clk_src = { 1641 .cmd_rcgr = 0x17998, 1642 .mnd_width = 16, 1643 .hid_width = 5, 1644 .parent_map = gcc_parent_map_0, 1645 .freq_tbl = ftbl_gcc_qupv3_wrap0_s6_clk_src, 1646 .clkr.hw.init = &gcc_qupv3_wrap0_s7_clk_src_init, 1647 }; 1648 1649 static struct clk_init_data gcc_qupv3_wrap1_s0_clk_src_init = { 1650 .name = "gcc_qupv3_wrap1_s0_clk_src", 1651 .parent_data = gcc_parent_data_0, 1652 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1653 .flags = CLK_SET_RATE_PARENT, 1654 .ops = &clk_rcg2_ops, 1655 }; 1656 1657 static struct clk_rcg2 gcc_qupv3_wrap1_s0_clk_src = { 1658 .cmd_rcgr = 0x18148, 1659 .mnd_width = 16, 1660 .hid_width = 5, 1661 .parent_map = gcc_parent_map_0, 1662 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1663 .clkr.hw.init = &gcc_qupv3_wrap1_s0_clk_src_init, 1664 }; 1665 1666 static struct clk_init_data gcc_qupv3_wrap1_s1_clk_src_init = { 1667 .name = "gcc_qupv3_wrap1_s1_clk_src", 1668 .parent_data = gcc_parent_data_0, 1669 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1670 .flags = CLK_SET_RATE_PARENT, 1671 .ops = &clk_rcg2_ops, 1672 }; 1673 1674 static struct clk_rcg2 gcc_qupv3_wrap1_s1_clk_src = { 1675 .cmd_rcgr = 0x18278, 1676 .mnd_width = 16, 1677 .hid_width = 5, 1678 .parent_map = gcc_parent_map_0, 1679 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1680 .clkr.hw.init = &gcc_qupv3_wrap1_s1_clk_src_init, 1681 }; 1682 1683 static struct clk_init_data gcc_qupv3_wrap1_s2_clk_src_init = { 1684 .name = "gcc_qupv3_wrap1_s2_clk_src", 1685 .parent_data = gcc_parent_data_0, 1686 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1687 .flags = CLK_SET_RATE_PARENT, 1688 .ops = &clk_rcg2_ops, 1689 }; 1690 1691 static struct clk_rcg2 gcc_qupv3_wrap1_s2_clk_src = { 1692 .cmd_rcgr = 0x183a8, 1693 .mnd_width = 16, 1694 .hid_width = 5, 1695 .parent_map = gcc_parent_map_0, 1696 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1697 .clkr.hw.init = &gcc_qupv3_wrap1_s2_clk_src_init, 1698 }; 1699 1700 static struct clk_init_data gcc_qupv3_wrap1_s3_clk_src_init = { 1701 .name = "gcc_qupv3_wrap1_s3_clk_src", 1702 .parent_data = gcc_parent_data_0, 1703 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1704 .flags = CLK_SET_RATE_PARENT, 1705 .ops = &clk_rcg2_ops, 1706 }; 1707 1708 static struct clk_rcg2 gcc_qupv3_wrap1_s3_clk_src = { 1709 .cmd_rcgr = 0x184d8, 1710 .mnd_width = 16, 1711 .hid_width = 5, 1712 .parent_map = gcc_parent_map_0, 1713 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1714 .clkr.hw.init = &gcc_qupv3_wrap1_s3_clk_src_init, 1715 }; 1716 1717 static struct clk_init_data gcc_qupv3_wrap1_s4_clk_src_init = { 1718 .name = "gcc_qupv3_wrap1_s4_clk_src", 1719 .parent_data = gcc_parent_data_0, 1720 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1721 .flags = CLK_SET_RATE_PARENT, 1722 .ops = &clk_rcg2_ops, 1723 }; 1724 1725 static struct clk_rcg2 gcc_qupv3_wrap1_s4_clk_src = { 1726 .cmd_rcgr = 0x18608, 1727 .mnd_width = 16, 1728 .hid_width = 5, 1729 .parent_map = gcc_parent_map_0, 1730 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1731 .clkr.hw.init = &gcc_qupv3_wrap1_s4_clk_src_init, 1732 }; 1733 1734 static struct clk_init_data gcc_qupv3_wrap1_s5_clk_src_init = { 1735 .name = "gcc_qupv3_wrap1_s5_clk_src", 1736 .parent_data = gcc_parent_data_0, 1737 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1738 .flags = CLK_SET_RATE_PARENT, 1739 .ops = &clk_rcg2_ops, 1740 }; 1741 1742 static struct clk_rcg2 gcc_qupv3_wrap1_s5_clk_src = { 1743 .cmd_rcgr = 0x18738, 1744 .mnd_width = 16, 1745 .hid_width = 5, 1746 .parent_map = gcc_parent_map_0, 1747 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1748 .clkr.hw.init = &gcc_qupv3_wrap1_s5_clk_src_init, 1749 }; 1750 1751 static struct clk_init_data gcc_qupv3_wrap1_s6_clk_src_init = { 1752 .name = "gcc_qupv3_wrap1_s6_clk_src", 1753 .parent_data = gcc_parent_data_0, 1754 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1755 .flags = CLK_SET_RATE_PARENT, 1756 .ops = &clk_rcg2_ops, 1757 }; 1758 1759 static struct clk_rcg2 gcc_qupv3_wrap1_s6_clk_src = { 1760 .cmd_rcgr = 0x18868, 1761 .mnd_width = 16, 1762 .hid_width = 5, 1763 .parent_map = gcc_parent_map_0, 1764 .freq_tbl = ftbl_gcc_qupv3_wrap0_s6_clk_src, 1765 .clkr.hw.init = &gcc_qupv3_wrap1_s6_clk_src_init, 1766 }; 1767 1768 static struct clk_init_data gcc_qupv3_wrap1_s7_clk_src_init = { 1769 .name = "gcc_qupv3_wrap1_s7_clk_src", 1770 .parent_data = gcc_parent_data_0, 1771 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1772 .flags = CLK_SET_RATE_PARENT, 1773 .ops = &clk_rcg2_ops, 1774 }; 1775 1776 static struct clk_rcg2 gcc_qupv3_wrap1_s7_clk_src = { 1777 .cmd_rcgr = 0x18998, 1778 .mnd_width = 16, 1779 .hid_width = 5, 1780 .parent_map = gcc_parent_map_0, 1781 .freq_tbl = ftbl_gcc_qupv3_wrap0_s6_clk_src, 1782 .clkr.hw.init = &gcc_qupv3_wrap1_s7_clk_src_init, 1783 }; 1784 1785 static struct clk_init_data gcc_qupv3_wrap2_s0_clk_src_init = { 1786 .name = "gcc_qupv3_wrap2_s0_clk_src", 1787 .parent_data = gcc_parent_data_0, 1788 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1789 .flags = CLK_SET_RATE_PARENT, 1790 .ops = &clk_rcg2_ops, 1791 }; 1792 1793 static struct clk_rcg2 gcc_qupv3_wrap2_s0_clk_src = { 1794 .cmd_rcgr = 0x1e148, 1795 .mnd_width = 16, 1796 .hid_width = 5, 1797 .parent_map = gcc_parent_map_0, 1798 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1799 .clkr.hw.init = &gcc_qupv3_wrap2_s0_clk_src_init, 1800 }; 1801 1802 static struct clk_init_data gcc_qupv3_wrap2_s1_clk_src_init = { 1803 .name = "gcc_qupv3_wrap2_s1_clk_src", 1804 .parent_data = gcc_parent_data_0, 1805 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1806 .flags = CLK_SET_RATE_PARENT, 1807 .ops = &clk_rcg2_ops, 1808 }; 1809 1810 static struct clk_rcg2 gcc_qupv3_wrap2_s1_clk_src = { 1811 .cmd_rcgr = 0x1e278, 1812 .mnd_width = 16, 1813 .hid_width = 5, 1814 .parent_map = gcc_parent_map_0, 1815 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1816 .clkr.hw.init = &gcc_qupv3_wrap2_s1_clk_src_init, 1817 }; 1818 1819 static struct clk_init_data gcc_qupv3_wrap2_s2_clk_src_init = { 1820 .name = "gcc_qupv3_wrap2_s2_clk_src", 1821 .parent_data = gcc_parent_data_0, 1822 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1823 .flags = CLK_SET_RATE_PARENT, 1824 .ops = &clk_rcg2_ops, 1825 }; 1826 1827 static struct clk_rcg2 gcc_qupv3_wrap2_s2_clk_src = { 1828 .cmd_rcgr = 0x1e3a8, 1829 .mnd_width = 16, 1830 .hid_width = 5, 1831 .parent_map = gcc_parent_map_0, 1832 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1833 .clkr.hw.init = &gcc_qupv3_wrap2_s2_clk_src_init, 1834 }; 1835 1836 static struct clk_init_data gcc_qupv3_wrap2_s3_clk_src_init = { 1837 .name = "gcc_qupv3_wrap2_s3_clk_src", 1838 .parent_data = gcc_parent_data_0, 1839 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1840 .flags = CLK_SET_RATE_PARENT, 1841 .ops = &clk_rcg2_ops, 1842 }; 1843 1844 static struct clk_rcg2 gcc_qupv3_wrap2_s3_clk_src = { 1845 .cmd_rcgr = 0x1e4d8, 1846 .mnd_width = 16, 1847 .hid_width = 5, 1848 .parent_map = gcc_parent_map_0, 1849 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1850 .clkr.hw.init = &gcc_qupv3_wrap2_s3_clk_src_init, 1851 }; 1852 1853 static struct clk_init_data gcc_qupv3_wrap2_s4_clk_src_init = { 1854 .name = "gcc_qupv3_wrap2_s4_clk_src", 1855 .parent_data = gcc_parent_data_0, 1856 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1857 .flags = CLK_SET_RATE_PARENT, 1858 .ops = &clk_rcg2_ops, 1859 }; 1860 1861 static struct clk_rcg2 gcc_qupv3_wrap2_s4_clk_src = { 1862 .cmd_rcgr = 0x1e608, 1863 .mnd_width = 16, 1864 .hid_width = 5, 1865 .parent_map = gcc_parent_map_0, 1866 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1867 .clkr.hw.init = &gcc_qupv3_wrap2_s4_clk_src_init, 1868 }; 1869 1870 static struct clk_init_data gcc_qupv3_wrap2_s5_clk_src_init = { 1871 .name = "gcc_qupv3_wrap2_s5_clk_src", 1872 .parent_data = gcc_parent_data_0, 1873 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1874 .flags = CLK_SET_RATE_PARENT, 1875 .ops = &clk_rcg2_ops, 1876 }; 1877 1878 static struct clk_rcg2 gcc_qupv3_wrap2_s5_clk_src = { 1879 .cmd_rcgr = 0x1e738, 1880 .mnd_width = 16, 1881 .hid_width = 5, 1882 .parent_map = gcc_parent_map_0, 1883 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 1884 .clkr.hw.init = &gcc_qupv3_wrap2_s5_clk_src_init, 1885 }; 1886 1887 static struct clk_init_data gcc_qupv3_wrap2_s6_clk_src_init = { 1888 .name = "gcc_qupv3_wrap2_s6_clk_src", 1889 .parent_data = gcc_parent_data_0, 1890 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1891 .flags = CLK_SET_RATE_PARENT, 1892 .ops = &clk_rcg2_ops, 1893 }; 1894 1895 static struct clk_rcg2 gcc_qupv3_wrap2_s6_clk_src = { 1896 .cmd_rcgr = 0x1e868, 1897 .mnd_width = 16, 1898 .hid_width = 5, 1899 .parent_map = gcc_parent_map_0, 1900 .freq_tbl = ftbl_gcc_qupv3_wrap0_s6_clk_src, 1901 .clkr.hw.init = &gcc_qupv3_wrap2_s6_clk_src_init, 1902 }; 1903 1904 static struct clk_init_data gcc_qupv3_wrap2_s7_clk_src_init = { 1905 .name = "gcc_qupv3_wrap2_s7_clk_src", 1906 .parent_data = gcc_parent_data_0, 1907 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1908 .flags = CLK_SET_RATE_PARENT, 1909 .ops = &clk_rcg2_ops, 1910 }; 1911 1912 static struct clk_rcg2 gcc_qupv3_wrap2_s7_clk_src = { 1913 .cmd_rcgr = 0x1e998, 1914 .mnd_width = 16, 1915 .hid_width = 5, 1916 .parent_map = gcc_parent_map_0, 1917 .freq_tbl = ftbl_gcc_qupv3_wrap0_s6_clk_src, 1918 .clkr.hw.init = &gcc_qupv3_wrap2_s7_clk_src_init, 1919 }; 1920 1921 static const struct freq_tbl ftbl_gcc_sdcc2_apps_clk_src[] = { 1922 F(400000, P_BI_TCXO, 12, 1, 4), 1923 F(25000000, P_GCC_GPLL0_OUT_EVEN, 12, 0, 0), 1924 F(50000000, P_GCC_GPLL0_OUT_EVEN, 6, 0, 0), 1925 F(100000000, P_GCC_GPLL0_OUT_EVEN, 3, 0, 0), 1926 F(202000000, P_GCC_GPLL9_OUT_MAIN, 4, 0, 0), 1927 { } 1928 }; 1929 1930 static struct clk_rcg2 gcc_sdcc2_apps_clk_src = { 1931 .cmd_rcgr = 0x1400c, 1932 .mnd_width = 8, 1933 .hid_width = 5, 1934 .parent_map = gcc_parent_map_15, 1935 .freq_tbl = ftbl_gcc_sdcc2_apps_clk_src, 1936 .clkr.hw.init = &(const struct clk_init_data) { 1937 .name = "gcc_sdcc2_apps_clk_src", 1938 .parent_data = gcc_parent_data_15, 1939 .num_parents = ARRAY_SIZE(gcc_parent_data_15), 1940 .ops = &clk_rcg2_shared_ops, 1941 }, 1942 }; 1943 1944 static const struct freq_tbl ftbl_gcc_sdcc4_apps_clk_src[] = { 1945 F(400000, P_BI_TCXO, 12, 1, 4), 1946 F(25000000, P_GCC_GPLL0_OUT_EVEN, 12, 0, 0), 1947 F(100000000, P_GCC_GPLL0_OUT_EVEN, 3, 0, 0), 1948 { } 1949 }; 1950 1951 static struct clk_rcg2 gcc_sdcc4_apps_clk_src = { 1952 .cmd_rcgr = 0x1600c, 1953 .mnd_width = 8, 1954 .hid_width = 5, 1955 .parent_map = gcc_parent_map_0, 1956 .freq_tbl = ftbl_gcc_sdcc4_apps_clk_src, 1957 .clkr.hw.init = &(const struct clk_init_data) { 1958 .name = "gcc_sdcc4_apps_clk_src", 1959 .parent_data = gcc_parent_data_0, 1960 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1961 .ops = &clk_rcg2_shared_ops, 1962 }, 1963 }; 1964 1965 static const struct freq_tbl ftbl_gcc_ufs_card_axi_clk_src[] = { 1966 F(25000000, P_GCC_GPLL0_OUT_EVEN, 12, 0, 0), 1967 F(75000000, P_GCC_GPLL0_OUT_EVEN, 4, 0, 0), 1968 F(150000000, P_GCC_GPLL0_OUT_MAIN, 4, 0, 0), 1969 F(300000000, P_GCC_GPLL0_OUT_MAIN, 2, 0, 0), 1970 { } 1971 }; 1972 1973 static struct clk_rcg2 gcc_ufs_card_axi_clk_src = { 1974 .cmd_rcgr = 0x75024, 1975 .mnd_width = 8, 1976 .hid_width = 5, 1977 .parent_map = gcc_parent_map_0, 1978 .freq_tbl = ftbl_gcc_ufs_card_axi_clk_src, 1979 .clkr.hw.init = &(const struct clk_init_data) { 1980 .name = "gcc_ufs_card_axi_clk_src", 1981 .parent_data = gcc_parent_data_0, 1982 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1983 .ops = &clk_rcg2_shared_ops, 1984 }, 1985 }; 1986 1987 static const struct freq_tbl ftbl_gcc_ufs_card_ice_core_clk_src[] = { 1988 F(75000000, P_GCC_GPLL0_OUT_EVEN, 4, 0, 0), 1989 F(150000000, P_GCC_GPLL0_OUT_MAIN, 4, 0, 0), 1990 F(300000000, P_GCC_GPLL0_OUT_MAIN, 2, 0, 0), 1991 { } 1992 }; 1993 1994 static struct clk_rcg2 gcc_ufs_card_ice_core_clk_src = { 1995 .cmd_rcgr = 0x7506c, 1996 .mnd_width = 0, 1997 .hid_width = 5, 1998 .parent_map = gcc_parent_map_0, 1999 .freq_tbl = ftbl_gcc_ufs_card_ice_core_clk_src, 2000 .clkr.hw.init = &(const struct clk_init_data) { 2001 .name = "gcc_ufs_card_ice_core_clk_src", 2002 .parent_data = gcc_parent_data_0, 2003 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 2004 .ops = &clk_rcg2_shared_ops, 2005 }, 2006 }; 2007 2008 static struct clk_rcg2 gcc_ufs_card_phy_aux_clk_src = { 2009 .cmd_rcgr = 0x750a0, 2010 .mnd_width = 0, 2011 .hid_width = 5, 2012 .parent_map = gcc_parent_map_3, 2013 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 2014 .clkr.hw.init = &(const struct clk_init_data) { 2015 .name = "gcc_ufs_card_phy_aux_clk_src", 2016 .parent_data = gcc_parent_data_3, 2017 .num_parents = ARRAY_SIZE(gcc_parent_data_3), 2018 .ops = &clk_rcg2_shared_ops, 2019 }, 2020 }; 2021 2022 static struct clk_rcg2 gcc_ufs_card_unipro_core_clk_src = { 2023 .cmd_rcgr = 0x75084, 2024 .mnd_width = 0, 2025 .hid_width = 5, 2026 .parent_map = gcc_parent_map_0, 2027 .freq_tbl = ftbl_gcc_ufs_card_ice_core_clk_src, 2028 .clkr.hw.init = &(const struct clk_init_data) { 2029 .name = "gcc_ufs_card_unipro_core_clk_src", 2030 .parent_data = gcc_parent_data_0, 2031 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 2032 .ops = &clk_rcg2_shared_ops, 2033 }, 2034 }; 2035 2036 static struct clk_rcg2 gcc_ufs_phy_axi_clk_src = { 2037 .cmd_rcgr = 0x77024, 2038 .mnd_width = 8, 2039 .hid_width = 5, 2040 .parent_map = gcc_parent_map_0, 2041 .freq_tbl = ftbl_gcc_ufs_card_axi_clk_src, 2042 .clkr.hw.init = &(const struct clk_init_data) { 2043 .name = "gcc_ufs_phy_axi_clk_src", 2044 .parent_data = gcc_parent_data_0, 2045 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 2046 .ops = &clk_rcg2_shared_ops, 2047 }, 2048 }; 2049 2050 static struct clk_rcg2 gcc_ufs_phy_ice_core_clk_src = { 2051 .cmd_rcgr = 0x7706c, 2052 .mnd_width = 0, 2053 .hid_width = 5, 2054 .parent_map = gcc_parent_map_0, 2055 .freq_tbl = ftbl_gcc_ufs_card_ice_core_clk_src, 2056 .clkr.hw.init = &(const struct clk_init_data) { 2057 .name = "gcc_ufs_phy_ice_core_clk_src", 2058 .parent_data = gcc_parent_data_0, 2059 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 2060 .ops = &clk_rcg2_shared_ops, 2061 }, 2062 }; 2063 2064 static struct clk_rcg2 gcc_ufs_phy_phy_aux_clk_src = { 2065 .cmd_rcgr = 0x770a0, 2066 .mnd_width = 0, 2067 .hid_width = 5, 2068 .parent_map = gcc_parent_map_3, 2069 .freq_tbl = ftbl_gcc_pcie_0_aux_clk_src, 2070 .clkr.hw.init = &(const struct clk_init_data) { 2071 .name = "gcc_ufs_phy_phy_aux_clk_src", 2072 .parent_data = gcc_parent_data_3, 2073 .num_parents = ARRAY_SIZE(gcc_parent_data_3), 2074 .ops = &clk_rcg2_shared_ops, 2075 }, 2076 }; 2077 2078 static struct clk_rcg2 gcc_ufs_phy_unipro_core_clk_src = { 2079 .cmd_rcgr = 0x77084, 2080 .mnd_width = 0, 2081 .hid_width = 5, 2082 .parent_map = gcc_parent_map_0, 2083 .freq_tbl = ftbl_gcc_ufs_card_ice_core_clk_src, 2084 .clkr.hw.init = &(const struct clk_init_data) { 2085 .name = "gcc_ufs_phy_unipro_core_clk_src", 2086 .parent_data = gcc_parent_data_0, 2087 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 2088 .ops = &clk_rcg2_shared_ops, 2089 }, 2090 }; 2091 2092 static const struct freq_tbl ftbl_gcc_usb30_mp_master_clk_src[] = { 2093 F(66666667, P_GCC_GPLL0_OUT_EVEN, 4.5, 0, 0), 2094 F(133333333, P_GCC_GPLL0_OUT_MAIN, 4.5, 0, 0), 2095 F(200000000, P_GCC_GPLL0_OUT_MAIN, 3, 0, 0), 2096 F(240000000, P_GCC_GPLL0_OUT_MAIN, 2.5, 0, 0), 2097 { } 2098 }; 2099 2100 static struct clk_rcg2 gcc_usb30_mp_master_clk_src = { 2101 .cmd_rcgr = 0xab020, 2102 .mnd_width = 8, 2103 .hid_width = 5, 2104 .parent_map = gcc_parent_map_0, 2105 .freq_tbl = ftbl_gcc_usb30_mp_master_clk_src, 2106 .clkr.hw.init = &(const struct clk_init_data) { 2107 .name = "gcc_usb30_mp_master_clk_src", 2108 .parent_data = gcc_parent_data_0, 2109 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 2110 .ops = &clk_rcg2_shared_ops, 2111 }, 2112 }; 2113 2114 static struct clk_rcg2 gcc_usb30_mp_mock_utmi_clk_src = { 2115 .cmd_rcgr = 0xab038, 2116 .mnd_width = 0, 2117 .hid_width = 5, 2118 .parent_map = gcc_parent_map_0, 2119 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 2120 .clkr.hw.init = &(const struct clk_init_data) { 2121 .name = "gcc_usb30_mp_mock_utmi_clk_src", 2122 .parent_data = gcc_parent_data_0, 2123 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 2124 .ops = &clk_rcg2_shared_ops, 2125 }, 2126 }; 2127 2128 static struct clk_rcg2 gcc_usb30_prim_master_clk_src = { 2129 .cmd_rcgr = 0xf020, 2130 .mnd_width = 8, 2131 .hid_width = 5, 2132 .parent_map = gcc_parent_map_0, 2133 .freq_tbl = ftbl_gcc_usb30_mp_master_clk_src, 2134 .clkr.hw.init = &(const struct clk_init_data) { 2135 .name = "gcc_usb30_prim_master_clk_src", 2136 .parent_data = gcc_parent_data_0, 2137 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 2138 .ops = &clk_rcg2_shared_ops, 2139 }, 2140 }; 2141 2142 static struct clk_rcg2 gcc_usb30_prim_mock_utmi_clk_src = { 2143 .cmd_rcgr = 0xf038, 2144 .mnd_width = 0, 2145 .hid_width = 5, 2146 .parent_map = gcc_parent_map_0, 2147 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 2148 .clkr.hw.init = &(const struct clk_init_data) { 2149 .name = "gcc_usb30_prim_mock_utmi_clk_src", 2150 .parent_data = gcc_parent_data_0, 2151 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 2152 .ops = &clk_rcg2_shared_ops, 2153 }, 2154 }; 2155 2156 static struct clk_rcg2 gcc_usb30_sec_master_clk_src = { 2157 .cmd_rcgr = 0x10020, 2158 .mnd_width = 8, 2159 .hid_width = 5, 2160 .parent_map = gcc_parent_map_0, 2161 .freq_tbl = ftbl_gcc_usb30_mp_master_clk_src, 2162 .clkr.hw.init = &(const struct clk_init_data) { 2163 .name = "gcc_usb30_sec_master_clk_src", 2164 .parent_data = gcc_parent_data_0, 2165 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 2166 .ops = &clk_rcg2_shared_ops, 2167 }, 2168 }; 2169 2170 static struct clk_rcg2 gcc_usb30_sec_mock_utmi_clk_src = { 2171 .cmd_rcgr = 0x10038, 2172 .mnd_width = 0, 2173 .hid_width = 5, 2174 .parent_map = gcc_parent_map_0, 2175 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 2176 .clkr.hw.init = &(const struct clk_init_data) { 2177 .name = "gcc_usb30_sec_mock_utmi_clk_src", 2178 .parent_data = gcc_parent_data_0, 2179 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 2180 .ops = &clk_rcg2_shared_ops, 2181 }, 2182 }; 2183 2184 static struct clk_rcg2 gcc_usb3_mp_phy_aux_clk_src = { 2185 .cmd_rcgr = 0xab06c, 2186 .mnd_width = 0, 2187 .hid_width = 5, 2188 .parent_map = gcc_parent_map_1, 2189 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 2190 .clkr.hw.init = &(const struct clk_init_data) { 2191 .name = "gcc_usb3_mp_phy_aux_clk_src", 2192 .parent_data = gcc_parent_data_1, 2193 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 2194 .ops = &clk_rcg2_shared_ops, 2195 }, 2196 }; 2197 2198 static struct clk_rcg2 gcc_usb3_prim_phy_aux_clk_src = { 2199 .cmd_rcgr = 0xf068, 2200 .mnd_width = 0, 2201 .hid_width = 5, 2202 .parent_map = gcc_parent_map_1, 2203 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 2204 .clkr.hw.init = &(const struct clk_init_data) { 2205 .name = "gcc_usb3_prim_phy_aux_clk_src", 2206 .parent_data = gcc_parent_data_1, 2207 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 2208 .ops = &clk_rcg2_shared_ops, 2209 }, 2210 }; 2211 2212 static struct clk_rcg2 gcc_usb3_sec_phy_aux_clk_src = { 2213 .cmd_rcgr = 0x10068, 2214 .mnd_width = 0, 2215 .hid_width = 5, 2216 .parent_map = gcc_parent_map_1, 2217 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 2218 .clkr.hw.init = &(const struct clk_init_data) { 2219 .name = "gcc_usb3_sec_phy_aux_clk_src", 2220 .parent_data = gcc_parent_data_1, 2221 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 2222 .ops = &clk_rcg2_shared_ops, 2223 }, 2224 }; 2225 2226 static const struct freq_tbl ftbl_gcc_usb4_1_master_clk_src[] = { 2227 F(85714286, P_GCC_GPLL0_OUT_EVEN, 3.5, 0, 0), 2228 F(175000000, P_GCC_GPLL8_OUT_MAIN, 4, 0, 0), 2229 F(350000000, P_GCC_GPLL8_OUT_MAIN, 2, 0, 0), 2230 { } 2231 }; 2232 2233 static struct clk_rcg2 gcc_usb4_1_master_clk_src = { 2234 .cmd_rcgr = 0xb8018, 2235 .mnd_width = 8, 2236 .hid_width = 5, 2237 .parent_map = gcc_parent_map_5, 2238 .freq_tbl = ftbl_gcc_usb4_1_master_clk_src, 2239 .clkr.hw.init = &(const struct clk_init_data) { 2240 .name = "gcc_usb4_1_master_clk_src", 2241 .parent_data = gcc_parent_data_5, 2242 .num_parents = ARRAY_SIZE(gcc_parent_data_5), 2243 .ops = &clk_rcg2_shared_ops, 2244 }, 2245 }; 2246 2247 static const struct freq_tbl ftbl_gcc_usb4_1_phy_pcie_pipe_clk_src[] = { 2248 F(19200000, P_BI_TCXO, 1, 0, 0), 2249 F(125000000, P_GCC_GPLL7_OUT_MAIN, 4, 0, 0), 2250 F(250000000, P_GCC_GPLL7_OUT_MAIN, 2, 0, 0), 2251 { } 2252 }; 2253 2254 static struct clk_rcg2 gcc_usb4_1_phy_pcie_pipe_clk_src = { 2255 .cmd_rcgr = 0xb80c4, 2256 .mnd_width = 0, 2257 .hid_width = 5, 2258 .parent_map = gcc_parent_map_6, 2259 .freq_tbl = ftbl_gcc_usb4_1_phy_pcie_pipe_clk_src, 2260 .clkr.hw.init = &(const struct clk_init_data) { 2261 .name = "gcc_usb4_1_phy_pcie_pipe_clk_src", 2262 .parent_data = gcc_parent_data_6, 2263 .num_parents = ARRAY_SIZE(gcc_parent_data_6), 2264 .ops = &clk_rcg2_shared_ops, 2265 }, 2266 }; 2267 2268 static struct clk_rcg2 gcc_usb4_1_sb_if_clk_src = { 2269 .cmd_rcgr = 0xb8070, 2270 .mnd_width = 0, 2271 .hid_width = 5, 2272 .parent_map = gcc_parent_map_1, 2273 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 2274 .clkr.hw.init = &(const struct clk_init_data) { 2275 .name = "gcc_usb4_1_sb_if_clk_src", 2276 .parent_data = gcc_parent_data_1, 2277 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 2278 .ops = &clk_rcg2_shared_ops, 2279 }, 2280 }; 2281 2282 static const struct freq_tbl ftbl_gcc_usb4_1_tmu_clk_src[] = { 2283 F(19200000, P_BI_TCXO, 1, 0, 0), 2284 F(250000000, P_GCC_GPLL2_OUT_MAIN, 4, 0, 0), 2285 { } 2286 }; 2287 2288 static struct clk_rcg2 gcc_usb4_1_tmu_clk_src = { 2289 .cmd_rcgr = 0xb8054, 2290 .mnd_width = 0, 2291 .hid_width = 5, 2292 .parent_map = gcc_parent_map_7, 2293 .freq_tbl = ftbl_gcc_usb4_1_tmu_clk_src, 2294 .clkr.hw.init = &(const struct clk_init_data) { 2295 .name = "gcc_usb4_1_tmu_clk_src", 2296 .parent_data = gcc_parent_data_7, 2297 .num_parents = ARRAY_SIZE(gcc_parent_data_7), 2298 .ops = &clk_rcg2_shared_ops, 2299 }, 2300 }; 2301 2302 static struct clk_rcg2 gcc_usb4_master_clk_src = { 2303 .cmd_rcgr = 0x2a018, 2304 .mnd_width = 8, 2305 .hid_width = 5, 2306 .parent_map = gcc_parent_map_5, 2307 .freq_tbl = ftbl_gcc_usb4_1_master_clk_src, 2308 .clkr.hw.init = &(const struct clk_init_data) { 2309 .name = "gcc_usb4_master_clk_src", 2310 .parent_data = gcc_parent_data_5, 2311 .num_parents = ARRAY_SIZE(gcc_parent_data_5), 2312 .ops = &clk_rcg2_shared_ops, 2313 }, 2314 }; 2315 2316 static struct clk_rcg2 gcc_usb4_phy_pcie_pipe_clk_src = { 2317 .cmd_rcgr = 0x2a0c4, 2318 .mnd_width = 0, 2319 .hid_width = 5, 2320 .parent_map = gcc_parent_map_6, 2321 .freq_tbl = ftbl_gcc_usb4_1_phy_pcie_pipe_clk_src, 2322 .clkr.hw.init = &(const struct clk_init_data) { 2323 .name = "gcc_usb4_phy_pcie_pipe_clk_src", 2324 .parent_data = gcc_parent_data_6, 2325 .num_parents = ARRAY_SIZE(gcc_parent_data_6), 2326 .ops = &clk_rcg2_shared_ops, 2327 }, 2328 }; 2329 2330 static struct clk_rcg2 gcc_usb4_sb_if_clk_src = { 2331 .cmd_rcgr = 0x2a070, 2332 .mnd_width = 0, 2333 .hid_width = 5, 2334 .parent_map = gcc_parent_map_1, 2335 .freq_tbl = ftbl_gcc_pcie_1_aux_clk_src, 2336 .clkr.hw.init = &(const struct clk_init_data) { 2337 .name = "gcc_usb4_sb_if_clk_src", 2338 .parent_data = gcc_parent_data_1, 2339 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 2340 .ops = &clk_rcg2_shared_ops, 2341 }, 2342 }; 2343 2344 static struct clk_rcg2 gcc_usb4_tmu_clk_src = { 2345 .cmd_rcgr = 0x2a054, 2346 .mnd_width = 0, 2347 .hid_width = 5, 2348 .parent_map = gcc_parent_map_7, 2349 .freq_tbl = ftbl_gcc_usb4_1_tmu_clk_src, 2350 .clkr.hw.init = &(const struct clk_init_data) { 2351 .name = "gcc_usb4_tmu_clk_src", 2352 .parent_data = gcc_parent_data_7, 2353 .num_parents = ARRAY_SIZE(gcc_parent_data_7), 2354 .ops = &clk_rcg2_shared_ops, 2355 }, 2356 }; 2357 2358 static struct clk_regmap_div gcc_pcie_2a_pipe_div_clk_src = { 2359 .reg = 0x9d060, 2360 .shift = 0, 2361 .width = 4, 2362 .clkr.hw.init = &(const struct clk_init_data) { 2363 .name = "gcc_pcie_2a_pipe_div_clk_src", 2364 .parent_hws = (const struct clk_hw*[]){ 2365 &gcc_pcie_2a_pipe_clk_src.clkr.hw, 2366 }, 2367 .num_parents = 1, 2368 .flags = CLK_SET_RATE_PARENT, 2369 .ops = &clk_regmap_div_ro_ops, 2370 }, 2371 }; 2372 2373 static struct clk_regmap_div gcc_pcie_2b_pipe_div_clk_src = { 2374 .reg = 0x9e060, 2375 .shift = 0, 2376 .width = 4, 2377 .clkr.hw.init = &(const struct clk_init_data) { 2378 .name = "gcc_pcie_2b_pipe_div_clk_src", 2379 .parent_hws = (const struct clk_hw*[]){ 2380 &gcc_pcie_2b_pipe_clk_src.clkr.hw, 2381 }, 2382 .num_parents = 1, 2383 .flags = CLK_SET_RATE_PARENT, 2384 .ops = &clk_regmap_div_ro_ops, 2385 }, 2386 }; 2387 2388 static struct clk_regmap_div gcc_pcie_3a_pipe_div_clk_src = { 2389 .reg = 0xa0060, 2390 .shift = 0, 2391 .width = 4, 2392 .clkr.hw.init = &(const struct clk_init_data) { 2393 .name = "gcc_pcie_3a_pipe_div_clk_src", 2394 .parent_hws = (const struct clk_hw*[]){ 2395 &gcc_pcie_3a_pipe_clk_src.clkr.hw, 2396 }, 2397 .num_parents = 1, 2398 .flags = CLK_SET_RATE_PARENT, 2399 .ops = &clk_regmap_div_ro_ops, 2400 }, 2401 }; 2402 2403 static struct clk_regmap_div gcc_pcie_3b_pipe_div_clk_src = { 2404 .reg = 0xa2060, 2405 .shift = 0, 2406 .width = 4, 2407 .clkr.hw.init = &(const struct clk_init_data) { 2408 .name = "gcc_pcie_3b_pipe_div_clk_src", 2409 .parent_hws = (const struct clk_hw*[]){ 2410 &gcc_pcie_3b_pipe_clk_src.clkr.hw, 2411 }, 2412 .num_parents = 1, 2413 .flags = CLK_SET_RATE_PARENT, 2414 .ops = &clk_regmap_div_ro_ops, 2415 }, 2416 }; 2417 2418 static struct clk_regmap_div gcc_pcie_4_pipe_div_clk_src = { 2419 .reg = 0x6b060, 2420 .shift = 0, 2421 .width = 4, 2422 .clkr.hw.init = &(const struct clk_init_data) { 2423 .name = "gcc_pcie_4_pipe_div_clk_src", 2424 .parent_hws = (const struct clk_hw*[]){ 2425 &gcc_pcie_4_pipe_clk_src.clkr.hw, 2426 }, 2427 .num_parents = 1, 2428 .flags = CLK_SET_RATE_PARENT, 2429 .ops = &clk_regmap_div_ro_ops, 2430 }, 2431 }; 2432 2433 static struct clk_regmap_div gcc_qupv3_wrap0_s4_div_clk_src = { 2434 .reg = 0x17ac8, 2435 .shift = 0, 2436 .width = 4, 2437 .clkr.hw.init = &(const struct clk_init_data) { 2438 .name = "gcc_qupv3_wrap0_s4_div_clk_src", 2439 .parent_hws = (const struct clk_hw*[]){ 2440 &gcc_qupv3_wrap0_s4_clk_src.clkr.hw, 2441 }, 2442 .num_parents = 1, 2443 .flags = CLK_SET_RATE_PARENT, 2444 .ops = &clk_regmap_div_ro_ops, 2445 }, 2446 }; 2447 2448 static struct clk_regmap_div gcc_qupv3_wrap1_s4_div_clk_src = { 2449 .reg = 0x18ac8, 2450 .shift = 0, 2451 .width = 4, 2452 .clkr.hw.init = &(const struct clk_init_data) { 2453 .name = "gcc_qupv3_wrap1_s4_div_clk_src", 2454 .parent_hws = (const struct clk_hw*[]){ 2455 &gcc_qupv3_wrap1_s4_clk_src.clkr.hw, 2456 }, 2457 .num_parents = 1, 2458 .flags = CLK_SET_RATE_PARENT, 2459 .ops = &clk_regmap_div_ro_ops, 2460 }, 2461 }; 2462 2463 static struct clk_regmap_div gcc_qupv3_wrap2_s4_div_clk_src = { 2464 .reg = 0x1eac8, 2465 .shift = 0, 2466 .width = 4, 2467 .clkr.hw.init = &(const struct clk_init_data) { 2468 .name = "gcc_qupv3_wrap2_s4_div_clk_src", 2469 .parent_hws = (const struct clk_hw*[]){ 2470 &gcc_qupv3_wrap2_s4_clk_src.clkr.hw, 2471 }, 2472 .num_parents = 1, 2473 .flags = CLK_SET_RATE_PARENT, 2474 .ops = &clk_regmap_div_ro_ops, 2475 }, 2476 }; 2477 2478 static struct clk_regmap_div gcc_usb30_mp_mock_utmi_postdiv_clk_src = { 2479 .reg = 0xab050, 2480 .shift = 0, 2481 .width = 4, 2482 .clkr.hw.init = &(const struct clk_init_data) { 2483 .name = "gcc_usb30_mp_mock_utmi_postdiv_clk_src", 2484 .parent_hws = (const struct clk_hw*[]){ 2485 &gcc_usb30_mp_mock_utmi_clk_src.clkr.hw, 2486 }, 2487 .num_parents = 1, 2488 .flags = CLK_SET_RATE_PARENT, 2489 .ops = &clk_regmap_div_ro_ops, 2490 }, 2491 }; 2492 2493 static struct clk_regmap_div gcc_usb30_prim_mock_utmi_postdiv_clk_src = { 2494 .reg = 0xf050, 2495 .shift = 0, 2496 .width = 4, 2497 .clkr.hw.init = &(const struct clk_init_data) { 2498 .name = "gcc_usb30_prim_mock_utmi_postdiv_clk_src", 2499 .parent_hws = (const struct clk_hw*[]){ 2500 &gcc_usb30_prim_mock_utmi_clk_src.clkr.hw, 2501 }, 2502 .num_parents = 1, 2503 .flags = CLK_SET_RATE_PARENT, 2504 .ops = &clk_regmap_div_ro_ops, 2505 }, 2506 }; 2507 2508 static struct clk_regmap_div gcc_usb30_sec_mock_utmi_postdiv_clk_src = { 2509 .reg = 0x10050, 2510 .shift = 0, 2511 .width = 4, 2512 .clkr.hw.init = &(const struct clk_init_data) { 2513 .name = "gcc_usb30_sec_mock_utmi_postdiv_clk_src", 2514 .parent_hws = (const struct clk_hw*[]){ 2515 &gcc_usb30_sec_mock_utmi_clk_src.clkr.hw, 2516 }, 2517 .num_parents = 1, 2518 .flags = CLK_SET_RATE_PARENT, 2519 .ops = &clk_regmap_div_ro_ops, 2520 }, 2521 }; 2522 2523 static struct clk_branch gcc_aggre_noc_pcie0_tunnel_axi_clk = { 2524 .halt_reg = 0xa41a8, 2525 .halt_check = BRANCH_HALT_SKIP, 2526 .hwcg_reg = 0xa41a8, 2527 .hwcg_bit = 1, 2528 .clkr = { 2529 .enable_reg = 0x52018, 2530 .enable_mask = BIT(14), 2531 .hw.init = &(const struct clk_init_data) { 2532 .name = "gcc_aggre_noc_pcie0_tunnel_axi_clk", 2533 .ops = &clk_branch2_ops, 2534 }, 2535 }, 2536 }; 2537 2538 static struct clk_branch gcc_aggre_noc_pcie1_tunnel_axi_clk = { 2539 .halt_reg = 0x8d07c, 2540 .halt_check = BRANCH_HALT_SKIP, 2541 .hwcg_reg = 0x8d07c, 2542 .hwcg_bit = 1, 2543 .clkr = { 2544 .enable_reg = 0x52018, 2545 .enable_mask = BIT(21), 2546 .hw.init = &(const struct clk_init_data) { 2547 .name = "gcc_aggre_noc_pcie1_tunnel_axi_clk", 2548 .ops = &clk_branch2_ops, 2549 }, 2550 }, 2551 }; 2552 2553 static struct clk_branch gcc_aggre_noc_pcie_4_axi_clk = { 2554 .halt_reg = 0x6b1b8, 2555 .halt_check = BRANCH_HALT_SKIP, 2556 .hwcg_reg = 0x6b1b8, 2557 .hwcg_bit = 1, 2558 .clkr = { 2559 .enable_reg = 0x52000, 2560 .enable_mask = BIT(12), 2561 .hw.init = &(const struct clk_init_data) { 2562 .name = "gcc_aggre_noc_pcie_4_axi_clk", 2563 .ops = &clk_branch2_ops, 2564 }, 2565 }, 2566 }; 2567 2568 static struct clk_branch gcc_aggre_noc_pcie_south_sf_axi_clk = { 2569 .halt_reg = 0xbf13c, 2570 .halt_check = BRANCH_HALT_SKIP, 2571 .hwcg_reg = 0xbf13c, 2572 .hwcg_bit = 1, 2573 .clkr = { 2574 .enable_reg = 0x52018, 2575 .enable_mask = BIT(13), 2576 .hw.init = &(const struct clk_init_data) { 2577 .name = "gcc_aggre_noc_pcie_south_sf_axi_clk", 2578 .ops = &clk_branch2_ops, 2579 }, 2580 }, 2581 }; 2582 2583 static struct clk_branch gcc_aggre_ufs_card_axi_clk = { 2584 .halt_reg = 0x750cc, 2585 .halt_check = BRANCH_HALT_VOTED, 2586 .hwcg_reg = 0x750cc, 2587 .hwcg_bit = 1, 2588 .clkr = { 2589 .enable_reg = 0x750cc, 2590 .enable_mask = BIT(0), 2591 .hw.init = &(const struct clk_init_data) { 2592 .name = "gcc_aggre_ufs_card_axi_clk", 2593 .parent_hws = (const struct clk_hw*[]){ 2594 &gcc_ufs_card_axi_clk_src.clkr.hw, 2595 }, 2596 .num_parents = 1, 2597 .flags = CLK_SET_RATE_PARENT, 2598 .ops = &clk_branch2_ops, 2599 }, 2600 }, 2601 }; 2602 2603 static struct clk_branch gcc_aggre_ufs_card_axi_hw_ctl_clk = { 2604 .halt_reg = 0x750cc, 2605 .halt_check = BRANCH_HALT_VOTED, 2606 .hwcg_reg = 0x750cc, 2607 .hwcg_bit = 1, 2608 .clkr = { 2609 .enable_reg = 0x750cc, 2610 .enable_mask = BIT(1), 2611 .hw.init = &(const struct clk_init_data) { 2612 .name = "gcc_aggre_ufs_card_axi_hw_ctl_clk", 2613 .parent_hws = (const struct clk_hw*[]){ 2614 &gcc_ufs_card_axi_clk_src.clkr.hw, 2615 }, 2616 .num_parents = 1, 2617 .flags = CLK_SET_RATE_PARENT, 2618 .ops = &clk_branch2_ops, 2619 }, 2620 }, 2621 }; 2622 2623 static struct clk_branch gcc_aggre_ufs_phy_axi_clk = { 2624 .halt_reg = 0x770cc, 2625 .halt_check = BRANCH_HALT_VOTED, 2626 .hwcg_reg = 0x770cc, 2627 .hwcg_bit = 1, 2628 .clkr = { 2629 .enable_reg = 0x770cc, 2630 .enable_mask = BIT(0), 2631 .hw.init = &(const struct clk_init_data) { 2632 .name = "gcc_aggre_ufs_phy_axi_clk", 2633 .parent_hws = (const struct clk_hw*[]){ 2634 &gcc_ufs_phy_axi_clk_src.clkr.hw, 2635 }, 2636 .num_parents = 1, 2637 .flags = CLK_SET_RATE_PARENT, 2638 .ops = &clk_branch2_ops, 2639 }, 2640 }, 2641 }; 2642 2643 static struct clk_branch gcc_aggre_ufs_phy_axi_hw_ctl_clk = { 2644 .halt_reg = 0x770cc, 2645 .halt_check = BRANCH_HALT_VOTED, 2646 .hwcg_reg = 0x770cc, 2647 .hwcg_bit = 1, 2648 .clkr = { 2649 .enable_reg = 0x770cc, 2650 .enable_mask = BIT(1), 2651 .hw.init = &(const struct clk_init_data) { 2652 .name = "gcc_aggre_ufs_phy_axi_hw_ctl_clk", 2653 .parent_hws = (const struct clk_hw*[]){ 2654 &gcc_ufs_phy_axi_clk_src.clkr.hw, 2655 }, 2656 .num_parents = 1, 2657 .flags = CLK_SET_RATE_PARENT, 2658 .ops = &clk_branch2_ops, 2659 }, 2660 }, 2661 }; 2662 2663 static struct clk_branch gcc_aggre_usb3_mp_axi_clk = { 2664 .halt_reg = 0xab084, 2665 .halt_check = BRANCH_HALT_VOTED, 2666 .hwcg_reg = 0xab084, 2667 .hwcg_bit = 1, 2668 .clkr = { 2669 .enable_reg = 0xab084, 2670 .enable_mask = BIT(0), 2671 .hw.init = &(const struct clk_init_data) { 2672 .name = "gcc_aggre_usb3_mp_axi_clk", 2673 .parent_hws = (const struct clk_hw*[]){ 2674 &gcc_usb30_mp_master_clk_src.clkr.hw, 2675 }, 2676 .num_parents = 1, 2677 .flags = CLK_SET_RATE_PARENT, 2678 .ops = &clk_branch2_ops, 2679 }, 2680 }, 2681 }; 2682 2683 static struct clk_branch gcc_aggre_usb3_prim_axi_clk = { 2684 .halt_reg = 0xf080, 2685 .halt_check = BRANCH_HALT_VOTED, 2686 .hwcg_reg = 0xf080, 2687 .hwcg_bit = 1, 2688 .clkr = { 2689 .enable_reg = 0xf080, 2690 .enable_mask = BIT(0), 2691 .hw.init = &(const struct clk_init_data) { 2692 .name = "gcc_aggre_usb3_prim_axi_clk", 2693 .parent_hws = (const struct clk_hw*[]){ 2694 &gcc_usb30_prim_master_clk_src.clkr.hw, 2695 }, 2696 .num_parents = 1, 2697 .flags = CLK_SET_RATE_PARENT, 2698 .ops = &clk_branch2_ops, 2699 }, 2700 }, 2701 }; 2702 2703 static struct clk_branch gcc_aggre_usb3_sec_axi_clk = { 2704 .halt_reg = 0x10080, 2705 .halt_check = BRANCH_HALT_VOTED, 2706 .hwcg_reg = 0x10080, 2707 .hwcg_bit = 1, 2708 .clkr = { 2709 .enable_reg = 0x10080, 2710 .enable_mask = BIT(0), 2711 .hw.init = &(const struct clk_init_data) { 2712 .name = "gcc_aggre_usb3_sec_axi_clk", 2713 .parent_hws = (const struct clk_hw*[]){ 2714 &gcc_usb30_sec_master_clk_src.clkr.hw, 2715 }, 2716 .num_parents = 1, 2717 .flags = CLK_SET_RATE_PARENT, 2718 .ops = &clk_branch2_ops, 2719 }, 2720 }, 2721 }; 2722 2723 static struct clk_branch gcc_aggre_usb4_1_axi_clk = { 2724 .halt_reg = 0xb80e4, 2725 .halt_check = BRANCH_HALT_VOTED, 2726 .hwcg_reg = 0xb80e4, 2727 .hwcg_bit = 1, 2728 .clkr = { 2729 .enable_reg = 0xb80e4, 2730 .enable_mask = BIT(0), 2731 .hw.init = &(const struct clk_init_data) { 2732 .name = "gcc_aggre_usb4_1_axi_clk", 2733 .parent_hws = (const struct clk_hw*[]){ 2734 &gcc_usb4_1_master_clk_src.clkr.hw, 2735 }, 2736 .num_parents = 1, 2737 .flags = CLK_SET_RATE_PARENT, 2738 .ops = &clk_branch2_ops, 2739 }, 2740 }, 2741 }; 2742 2743 static struct clk_branch gcc_aggre_usb4_axi_clk = { 2744 .halt_reg = 0x2a0e4, 2745 .halt_check = BRANCH_HALT_VOTED, 2746 .hwcg_reg = 0x2a0e4, 2747 .hwcg_bit = 1, 2748 .clkr = { 2749 .enable_reg = 0x2a0e4, 2750 .enable_mask = BIT(0), 2751 .hw.init = &(const struct clk_init_data) { 2752 .name = "gcc_aggre_usb4_axi_clk", 2753 .parent_hws = (const struct clk_hw*[]){ 2754 &gcc_usb4_master_clk_src.clkr.hw, 2755 }, 2756 .num_parents = 1, 2757 .flags = CLK_SET_RATE_PARENT, 2758 .ops = &clk_branch2_ops, 2759 }, 2760 }, 2761 }; 2762 2763 static struct clk_branch gcc_aggre_usb_noc_axi_clk = { 2764 .halt_reg = 0x5d024, 2765 .halt_check = BRANCH_HALT_VOTED, 2766 .hwcg_reg = 0x5d024, 2767 .hwcg_bit = 1, 2768 .clkr = { 2769 .enable_reg = 0x5d024, 2770 .enable_mask = BIT(0), 2771 .hw.init = &(const struct clk_init_data) { 2772 .name = "gcc_aggre_usb_noc_axi_clk", 2773 .ops = &clk_branch2_ops, 2774 }, 2775 }, 2776 }; 2777 2778 static struct clk_branch gcc_aggre_usb_noc_north_axi_clk = { 2779 .halt_reg = 0x5d020, 2780 .halt_check = BRANCH_HALT_VOTED, 2781 .hwcg_reg = 0x5d020, 2782 .hwcg_bit = 1, 2783 .clkr = { 2784 .enable_reg = 0x5d020, 2785 .enable_mask = BIT(0), 2786 .hw.init = &(const struct clk_init_data) { 2787 .name = "gcc_aggre_usb_noc_north_axi_clk", 2788 .ops = &clk_branch2_ops, 2789 }, 2790 }, 2791 }; 2792 2793 static struct clk_branch gcc_aggre_usb_noc_south_axi_clk = { 2794 .halt_reg = 0x5d01c, 2795 .halt_check = BRANCH_HALT_VOTED, 2796 .hwcg_reg = 0x5d01c, 2797 .hwcg_bit = 1, 2798 .clkr = { 2799 .enable_reg = 0x5d01c, 2800 .enable_mask = BIT(0), 2801 .hw.init = &(const struct clk_init_data) { 2802 .name = "gcc_aggre_usb_noc_south_axi_clk", 2803 .ops = &clk_branch2_ops, 2804 }, 2805 }, 2806 }; 2807 2808 static struct clk_branch gcc_ahb2phy0_clk = { 2809 .halt_reg = 0x6a004, 2810 .halt_check = BRANCH_HALT_VOTED, 2811 .hwcg_reg = 0x6a004, 2812 .hwcg_bit = 1, 2813 .clkr = { 2814 .enable_reg = 0x6a004, 2815 .enable_mask = BIT(0), 2816 .hw.init = &(const struct clk_init_data) { 2817 .name = "gcc_ahb2phy0_clk", 2818 .ops = &clk_branch2_ops, 2819 }, 2820 }, 2821 }; 2822 2823 static struct clk_branch gcc_ahb2phy2_clk = { 2824 .halt_reg = 0x6a008, 2825 .halt_check = BRANCH_HALT_VOTED, 2826 .hwcg_reg = 0x6a008, 2827 .hwcg_bit = 1, 2828 .clkr = { 2829 .enable_reg = 0x6a008, 2830 .enable_mask = BIT(0), 2831 .hw.init = &(const struct clk_init_data) { 2832 .name = "gcc_ahb2phy2_clk", 2833 .ops = &clk_branch2_ops, 2834 }, 2835 }, 2836 }; 2837 2838 static struct clk_branch gcc_boot_rom_ahb_clk = { 2839 .halt_reg = 0x38004, 2840 .halt_check = BRANCH_HALT_VOTED, 2841 .hwcg_reg = 0x38004, 2842 .hwcg_bit = 1, 2843 .clkr = { 2844 .enable_reg = 0x52000, 2845 .enable_mask = BIT(10), 2846 .hw.init = &(const struct clk_init_data) { 2847 .name = "gcc_boot_rom_ahb_clk", 2848 .ops = &clk_branch2_ops, 2849 }, 2850 }, 2851 }; 2852 2853 static struct clk_branch gcc_camera_hf_axi_clk = { 2854 .halt_reg = 0x26010, 2855 .halt_check = BRANCH_HALT_SKIP, 2856 .hwcg_reg = 0x26010, 2857 .hwcg_bit = 1, 2858 .clkr = { 2859 .enable_reg = 0x26010, 2860 .enable_mask = BIT(0), 2861 .hw.init = &(const struct clk_init_data) { 2862 .name = "gcc_camera_hf_axi_clk", 2863 .ops = &clk_branch2_ops, 2864 }, 2865 }, 2866 }; 2867 2868 static struct clk_branch gcc_camera_sf_axi_clk = { 2869 .halt_reg = 0x26014, 2870 .halt_check = BRANCH_HALT_SKIP, 2871 .hwcg_reg = 0x26014, 2872 .hwcg_bit = 1, 2873 .clkr = { 2874 .enable_reg = 0x26014, 2875 .enable_mask = BIT(0), 2876 .hw.init = &(const struct clk_init_data) { 2877 .name = "gcc_camera_sf_axi_clk", 2878 .ops = &clk_branch2_ops, 2879 }, 2880 }, 2881 }; 2882 2883 static struct clk_branch gcc_camera_throttle_nrt_axi_clk = { 2884 .halt_reg = 0x2601c, 2885 .halt_check = BRANCH_HALT_SKIP, 2886 .hwcg_reg = 0x2601c, 2887 .hwcg_bit = 1, 2888 .clkr = { 2889 .enable_reg = 0x2601c, 2890 .enable_mask = BIT(0), 2891 .hw.init = &(const struct clk_init_data) { 2892 .name = "gcc_camera_throttle_nrt_axi_clk", 2893 .ops = &clk_branch2_ops, 2894 }, 2895 }, 2896 }; 2897 2898 static struct clk_branch gcc_camera_throttle_rt_axi_clk = { 2899 .halt_reg = 0x26018, 2900 .halt_check = BRANCH_HALT_SKIP, 2901 .hwcg_reg = 0x26018, 2902 .hwcg_bit = 1, 2903 .clkr = { 2904 .enable_reg = 0x26018, 2905 .enable_mask = BIT(0), 2906 .hw.init = &(const struct clk_init_data) { 2907 .name = "gcc_camera_throttle_rt_axi_clk", 2908 .ops = &clk_branch2_ops, 2909 }, 2910 }, 2911 }; 2912 2913 static struct clk_branch gcc_camera_throttle_xo_clk = { 2914 .halt_reg = 0x26024, 2915 .halt_check = BRANCH_HALT, 2916 .clkr = { 2917 .enable_reg = 0x26024, 2918 .enable_mask = BIT(0), 2919 .hw.init = &(const struct clk_init_data) { 2920 .name = "gcc_camera_throttle_xo_clk", 2921 .ops = &clk_branch2_ops, 2922 }, 2923 }, 2924 }; 2925 2926 static struct clk_branch gcc_cfg_noc_usb3_mp_axi_clk = { 2927 .halt_reg = 0xab088, 2928 .halt_check = BRANCH_HALT_VOTED, 2929 .hwcg_reg = 0xab088, 2930 .hwcg_bit = 1, 2931 .clkr = { 2932 .enable_reg = 0xab088, 2933 .enable_mask = BIT(0), 2934 .hw.init = &(const struct clk_init_data) { 2935 .name = "gcc_cfg_noc_usb3_mp_axi_clk", 2936 .parent_hws = (const struct clk_hw*[]){ 2937 &gcc_usb30_mp_master_clk_src.clkr.hw, 2938 }, 2939 .num_parents = 1, 2940 .flags = CLK_SET_RATE_PARENT, 2941 .ops = &clk_branch2_ops, 2942 }, 2943 }, 2944 }; 2945 2946 static struct clk_branch gcc_cfg_noc_usb3_prim_axi_clk = { 2947 .halt_reg = 0xf084, 2948 .halt_check = BRANCH_HALT_VOTED, 2949 .hwcg_reg = 0xf084, 2950 .hwcg_bit = 1, 2951 .clkr = { 2952 .enable_reg = 0xf084, 2953 .enable_mask = BIT(0), 2954 .hw.init = &(const struct clk_init_data) { 2955 .name = "gcc_cfg_noc_usb3_prim_axi_clk", 2956 .parent_hws = (const struct clk_hw*[]){ 2957 &gcc_usb30_prim_master_clk_src.clkr.hw, 2958 }, 2959 .num_parents = 1, 2960 .flags = CLK_SET_RATE_PARENT, 2961 .ops = &clk_branch2_ops, 2962 }, 2963 }, 2964 }; 2965 2966 static struct clk_branch gcc_cfg_noc_usb3_sec_axi_clk = { 2967 .halt_reg = 0x10084, 2968 .halt_check = BRANCH_HALT_VOTED, 2969 .hwcg_reg = 0x10084, 2970 .hwcg_bit = 1, 2971 .clkr = { 2972 .enable_reg = 0x10084, 2973 .enable_mask = BIT(0), 2974 .hw.init = &(const struct clk_init_data) { 2975 .name = "gcc_cfg_noc_usb3_sec_axi_clk", 2976 .parent_hws = (const struct clk_hw*[]){ 2977 &gcc_usb30_sec_master_clk_src.clkr.hw, 2978 }, 2979 .num_parents = 1, 2980 .flags = CLK_SET_RATE_PARENT, 2981 .ops = &clk_branch2_ops, 2982 }, 2983 }, 2984 }; 2985 2986 static struct clk_branch gcc_cnoc_pcie0_tunnel_clk = { 2987 .halt_reg = 0xa4074, 2988 .halt_check = BRANCH_HALT_VOTED, 2989 .clkr = { 2990 .enable_reg = 0x52020, 2991 .enable_mask = BIT(8), 2992 .hw.init = &(const struct clk_init_data) { 2993 .name = "gcc_cnoc_pcie0_tunnel_clk", 2994 .ops = &clk_branch2_ops, 2995 }, 2996 }, 2997 }; 2998 2999 static struct clk_branch gcc_cnoc_pcie1_tunnel_clk = { 3000 .halt_reg = 0x8d074, 3001 .halt_check = BRANCH_HALT_VOTED, 3002 .clkr = { 3003 .enable_reg = 0x52020, 3004 .enable_mask = BIT(9), 3005 .hw.init = &(const struct clk_init_data) { 3006 .name = "gcc_cnoc_pcie1_tunnel_clk", 3007 .ops = &clk_branch2_ops, 3008 }, 3009 }, 3010 }; 3011 3012 static struct clk_branch gcc_cnoc_pcie4_qx_clk = { 3013 .halt_reg = 0x6b084, 3014 .halt_check = BRANCH_HALT_VOTED, 3015 .hwcg_reg = 0x6b084, 3016 .hwcg_bit = 1, 3017 .clkr = { 3018 .enable_reg = 0x52020, 3019 .enable_mask = BIT(10), 3020 .hw.init = &(const struct clk_init_data) { 3021 .name = "gcc_cnoc_pcie4_qx_clk", 3022 .ops = &clk_branch2_ops, 3023 }, 3024 }, 3025 }; 3026 3027 static struct clk_branch gcc_ddrss_gpu_axi_clk = { 3028 .halt_reg = 0x7115c, 3029 .halt_check = BRANCH_HALT_SKIP, 3030 .hwcg_reg = 0x7115c, 3031 .hwcg_bit = 1, 3032 .clkr = { 3033 .enable_reg = 0x7115c, 3034 .enable_mask = BIT(0), 3035 .hw.init = &(const struct clk_init_data) { 3036 .name = "gcc_ddrss_gpu_axi_clk", 3037 .ops = &clk_branch2_aon_ops, 3038 }, 3039 }, 3040 }; 3041 3042 static struct clk_branch gcc_ddrss_pcie_sf_tbu_clk = { 3043 .halt_reg = 0xa602c, 3044 .halt_check = BRANCH_HALT_SKIP, 3045 .hwcg_reg = 0xa602c, 3046 .hwcg_bit = 1, 3047 .clkr = { 3048 .enable_reg = 0x52000, 3049 .enable_mask = BIT(19), 3050 .hw.init = &(const struct clk_init_data) { 3051 .name = "gcc_ddrss_pcie_sf_tbu_clk", 3052 .ops = &clk_branch2_ops, 3053 }, 3054 }, 3055 }; 3056 3057 static struct clk_branch gcc_disp1_hf_axi_clk = { 3058 .halt_reg = 0xbb010, 3059 .halt_check = BRANCH_HALT_SKIP, 3060 .hwcg_reg = 0xbb010, 3061 .hwcg_bit = 1, 3062 .clkr = { 3063 .enable_reg = 0xbb010, 3064 .enable_mask = BIT(0), 3065 .hw.init = &(const struct clk_init_data) { 3066 .name = "gcc_disp1_hf_axi_clk", 3067 .ops = &clk_branch2_ops, 3068 }, 3069 }, 3070 }; 3071 3072 static struct clk_branch gcc_disp1_sf_axi_clk = { 3073 .halt_reg = 0xbb018, 3074 .halt_check = BRANCH_HALT_SKIP, 3075 .hwcg_reg = 0xbb018, 3076 .hwcg_bit = 1, 3077 .clkr = { 3078 .enable_reg = 0xbb018, 3079 .enable_mask = BIT(0), 3080 .hw.init = &(const struct clk_init_data) { 3081 .name = "gcc_disp1_sf_axi_clk", 3082 .ops = &clk_branch2_ops, 3083 }, 3084 }, 3085 }; 3086 3087 static struct clk_branch gcc_disp1_throttle_nrt_axi_clk = { 3088 .halt_reg = 0xbb024, 3089 .halt_check = BRANCH_HALT_SKIP, 3090 .hwcg_reg = 0xbb024, 3091 .hwcg_bit = 1, 3092 .clkr = { 3093 .enable_reg = 0xbb024, 3094 .enable_mask = BIT(0), 3095 .hw.init = &(const struct clk_init_data) { 3096 .name = "gcc_disp1_throttle_nrt_axi_clk", 3097 .ops = &clk_branch2_ops, 3098 }, 3099 }, 3100 }; 3101 3102 static struct clk_branch gcc_disp1_throttle_rt_axi_clk = { 3103 .halt_reg = 0xbb020, 3104 .halt_check = BRANCH_HALT_SKIP, 3105 .hwcg_reg = 0xbb020, 3106 .hwcg_bit = 1, 3107 .clkr = { 3108 .enable_reg = 0xbb020, 3109 .enable_mask = BIT(0), 3110 .hw.init = &(const struct clk_init_data) { 3111 .name = "gcc_disp1_throttle_rt_axi_clk", 3112 .ops = &clk_branch2_ops, 3113 }, 3114 }, 3115 }; 3116 3117 static struct clk_branch gcc_disp_hf_axi_clk = { 3118 .halt_reg = 0x27010, 3119 .halt_check = BRANCH_HALT_SKIP, 3120 .hwcg_reg = 0x27010, 3121 .hwcg_bit = 1, 3122 .clkr = { 3123 .enable_reg = 0x27010, 3124 .enable_mask = BIT(0), 3125 .hw.init = &(const struct clk_init_data) { 3126 .name = "gcc_disp_hf_axi_clk", 3127 .ops = &clk_branch2_ops, 3128 }, 3129 }, 3130 }; 3131 3132 static struct clk_branch gcc_disp_sf_axi_clk = { 3133 .halt_reg = 0x27018, 3134 .halt_check = BRANCH_HALT_SKIP, 3135 .hwcg_reg = 0x27018, 3136 .hwcg_bit = 1, 3137 .clkr = { 3138 .enable_reg = 0x27018, 3139 .enable_mask = BIT(0), 3140 .hw.init = &(const struct clk_init_data) { 3141 .name = "gcc_disp_sf_axi_clk", 3142 .ops = &clk_branch2_ops, 3143 }, 3144 }, 3145 }; 3146 3147 static struct clk_branch gcc_disp_throttle_nrt_axi_clk = { 3148 .halt_reg = 0x27024, 3149 .halt_check = BRANCH_HALT_SKIP, 3150 .hwcg_reg = 0x27024, 3151 .hwcg_bit = 1, 3152 .clkr = { 3153 .enable_reg = 0x27024, 3154 .enable_mask = BIT(0), 3155 .hw.init = &(const struct clk_init_data) { 3156 .name = "gcc_disp_throttle_nrt_axi_clk", 3157 .ops = &clk_branch2_ops, 3158 }, 3159 }, 3160 }; 3161 3162 static struct clk_branch gcc_disp_throttle_rt_axi_clk = { 3163 .halt_reg = 0x27020, 3164 .halt_check = BRANCH_HALT_SKIP, 3165 .hwcg_reg = 0x27020, 3166 .hwcg_bit = 1, 3167 .clkr = { 3168 .enable_reg = 0x27020, 3169 .enable_mask = BIT(0), 3170 .hw.init = &(const struct clk_init_data) { 3171 .name = "gcc_disp_throttle_rt_axi_clk", 3172 .ops = &clk_branch2_ops, 3173 }, 3174 }, 3175 }; 3176 3177 static struct clk_branch gcc_emac0_axi_clk = { 3178 .halt_reg = 0xaa010, 3179 .halt_check = BRANCH_HALT_VOTED, 3180 .hwcg_reg = 0xaa010, 3181 .hwcg_bit = 1, 3182 .clkr = { 3183 .enable_reg = 0xaa010, 3184 .enable_mask = BIT(0), 3185 .hw.init = &(const struct clk_init_data) { 3186 .name = "gcc_emac0_axi_clk", 3187 .ops = &clk_branch2_ops, 3188 }, 3189 }, 3190 }; 3191 3192 static struct clk_branch gcc_emac0_ptp_clk = { 3193 .halt_reg = 0xaa01c, 3194 .halt_check = BRANCH_HALT, 3195 .clkr = { 3196 .enable_reg = 0xaa01c, 3197 .enable_mask = BIT(0), 3198 .hw.init = &(const struct clk_init_data) { 3199 .name = "gcc_emac0_ptp_clk", 3200 .parent_hws = (const struct clk_hw*[]){ 3201 &gcc_emac0_ptp_clk_src.clkr.hw, 3202 }, 3203 .num_parents = 1, 3204 .flags = CLK_SET_RATE_PARENT, 3205 .ops = &clk_branch2_ops, 3206 }, 3207 }, 3208 }; 3209 3210 static struct clk_branch gcc_emac0_rgmii_clk = { 3211 .halt_reg = 0xaa038, 3212 .halt_check = BRANCH_HALT, 3213 .clkr = { 3214 .enable_reg = 0xaa038, 3215 .enable_mask = BIT(0), 3216 .hw.init = &(const struct clk_init_data) { 3217 .name = "gcc_emac0_rgmii_clk", 3218 .parent_hws = (const struct clk_hw*[]){ 3219 &gcc_emac0_rgmii_clk_src.clkr.hw, 3220 }, 3221 .num_parents = 1, 3222 .flags = CLK_SET_RATE_PARENT, 3223 .ops = &clk_branch2_ops, 3224 }, 3225 }, 3226 }; 3227 3228 static struct clk_branch gcc_emac0_slv_ahb_clk = { 3229 .halt_reg = 0xaa018, 3230 .halt_check = BRANCH_HALT_VOTED, 3231 .hwcg_reg = 0xaa018, 3232 .hwcg_bit = 1, 3233 .clkr = { 3234 .enable_reg = 0xaa018, 3235 .enable_mask = BIT(0), 3236 .hw.init = &(const struct clk_init_data) { 3237 .name = "gcc_emac0_slv_ahb_clk", 3238 .ops = &clk_branch2_ops, 3239 }, 3240 }, 3241 }; 3242 3243 static struct clk_branch gcc_emac1_axi_clk = { 3244 .halt_reg = 0xba010, 3245 .halt_check = BRANCH_HALT_VOTED, 3246 .hwcg_reg = 0xba010, 3247 .hwcg_bit = 1, 3248 .clkr = { 3249 .enable_reg = 0xba010, 3250 .enable_mask = BIT(0), 3251 .hw.init = &(const struct clk_init_data) { 3252 .name = "gcc_emac1_axi_clk", 3253 .ops = &clk_branch2_ops, 3254 }, 3255 }, 3256 }; 3257 3258 static struct clk_branch gcc_emac1_ptp_clk = { 3259 .halt_reg = 0xba01c, 3260 .halt_check = BRANCH_HALT, 3261 .clkr = { 3262 .enable_reg = 0xba01c, 3263 .enable_mask = BIT(0), 3264 .hw.init = &(const struct clk_init_data) { 3265 .name = "gcc_emac1_ptp_clk", 3266 .parent_hws = (const struct clk_hw*[]){ 3267 &gcc_emac1_ptp_clk_src.clkr.hw, 3268 }, 3269 .num_parents = 1, 3270 .flags = CLK_SET_RATE_PARENT, 3271 .ops = &clk_branch2_ops, 3272 }, 3273 }, 3274 }; 3275 3276 static struct clk_branch gcc_emac1_rgmii_clk = { 3277 .halt_reg = 0xba038, 3278 .halt_check = BRANCH_HALT, 3279 .clkr = { 3280 .enable_reg = 0xba038, 3281 .enable_mask = BIT(0), 3282 .hw.init = &(const struct clk_init_data) { 3283 .name = "gcc_emac1_rgmii_clk", 3284 .parent_hws = (const struct clk_hw*[]){ 3285 &gcc_emac1_rgmii_clk_src.clkr.hw, 3286 }, 3287 .num_parents = 1, 3288 .flags = CLK_SET_RATE_PARENT, 3289 .ops = &clk_branch2_ops, 3290 }, 3291 }, 3292 }; 3293 3294 static struct clk_branch gcc_emac1_slv_ahb_clk = { 3295 .halt_reg = 0xba018, 3296 .halt_check = BRANCH_HALT_VOTED, 3297 .hwcg_reg = 0xba018, 3298 .hwcg_bit = 1, 3299 .clkr = { 3300 .enable_reg = 0xba018, 3301 .enable_mask = BIT(0), 3302 .hw.init = &(const struct clk_init_data) { 3303 .name = "gcc_emac1_slv_ahb_clk", 3304 .ops = &clk_branch2_ops, 3305 }, 3306 }, 3307 }; 3308 3309 static struct clk_branch gcc_gp1_clk = { 3310 .halt_reg = 0x64000, 3311 .halt_check = BRANCH_HALT, 3312 .clkr = { 3313 .enable_reg = 0x64000, 3314 .enable_mask = BIT(0), 3315 .hw.init = &(const struct clk_init_data) { 3316 .name = "gcc_gp1_clk", 3317 .parent_hws = (const struct clk_hw*[]){ 3318 &gcc_gp1_clk_src.clkr.hw, 3319 }, 3320 .num_parents = 1, 3321 .flags = CLK_SET_RATE_PARENT, 3322 .ops = &clk_branch2_ops, 3323 }, 3324 }, 3325 }; 3326 3327 static struct clk_branch gcc_gp2_clk = { 3328 .halt_reg = 0x65000, 3329 .halt_check = BRANCH_HALT, 3330 .clkr = { 3331 .enable_reg = 0x65000, 3332 .enable_mask = BIT(0), 3333 .hw.init = &(const struct clk_init_data) { 3334 .name = "gcc_gp2_clk", 3335 .parent_hws = (const struct clk_hw*[]){ 3336 &gcc_gp2_clk_src.clkr.hw, 3337 }, 3338 .num_parents = 1, 3339 .flags = CLK_SET_RATE_PARENT, 3340 .ops = &clk_branch2_ops, 3341 }, 3342 }, 3343 }; 3344 3345 static struct clk_branch gcc_gp3_clk = { 3346 .halt_reg = 0x66000, 3347 .halt_check = BRANCH_HALT, 3348 .clkr = { 3349 .enable_reg = 0x66000, 3350 .enable_mask = BIT(0), 3351 .hw.init = &(const struct clk_init_data) { 3352 .name = "gcc_gp3_clk", 3353 .parent_hws = (const struct clk_hw*[]){ 3354 &gcc_gp3_clk_src.clkr.hw, 3355 }, 3356 .num_parents = 1, 3357 .flags = CLK_SET_RATE_PARENT, 3358 .ops = &clk_branch2_ops, 3359 }, 3360 }, 3361 }; 3362 3363 static struct clk_branch gcc_gp4_clk = { 3364 .halt_reg = 0xc2000, 3365 .halt_check = BRANCH_HALT, 3366 .clkr = { 3367 .enable_reg = 0xc2000, 3368 .enable_mask = BIT(0), 3369 .hw.init = &(const struct clk_init_data) { 3370 .name = "gcc_gp4_clk", 3371 .parent_hws = (const struct clk_hw*[]){ 3372 &gcc_gp4_clk_src.clkr.hw, 3373 }, 3374 .num_parents = 1, 3375 .flags = CLK_SET_RATE_PARENT, 3376 .ops = &clk_branch2_ops, 3377 }, 3378 }, 3379 }; 3380 3381 static struct clk_branch gcc_gp5_clk = { 3382 .halt_reg = 0xc3000, 3383 .halt_check = BRANCH_HALT, 3384 .clkr = { 3385 .enable_reg = 0xc3000, 3386 .enable_mask = BIT(0), 3387 .hw.init = &(const struct clk_init_data) { 3388 .name = "gcc_gp5_clk", 3389 .parent_hws = (const struct clk_hw*[]){ 3390 &gcc_gp5_clk_src.clkr.hw, 3391 }, 3392 .num_parents = 1, 3393 .flags = CLK_SET_RATE_PARENT, 3394 .ops = &clk_branch2_ops, 3395 }, 3396 }, 3397 }; 3398 3399 static struct clk_branch gcc_gpu_gpll0_clk_src = { 3400 .halt_check = BRANCH_HALT_DELAY, 3401 .clkr = { 3402 .enable_reg = 0x52000, 3403 .enable_mask = BIT(15), 3404 .hw.init = &(const struct clk_init_data) { 3405 .name = "gcc_gpu_gpll0_clk_src", 3406 .parent_hws = (const struct clk_hw*[]){ 3407 &gcc_gpll0.clkr.hw, 3408 }, 3409 .num_parents = 1, 3410 .flags = CLK_SET_RATE_PARENT, 3411 .ops = &clk_branch2_ops, 3412 }, 3413 }, 3414 }; 3415 3416 static struct clk_branch gcc_gpu_gpll0_div_clk_src = { 3417 .halt_check = BRANCH_HALT_DELAY, 3418 .clkr = { 3419 .enable_reg = 0x52000, 3420 .enable_mask = BIT(16), 3421 .hw.init = &(const struct clk_init_data) { 3422 .name = "gcc_gpu_gpll0_div_clk_src", 3423 .parent_hws = (const struct clk_hw*[]){ 3424 &gcc_gpll0_out_even.clkr.hw, 3425 }, 3426 .num_parents = 1, 3427 .flags = CLK_SET_RATE_PARENT, 3428 .ops = &clk_branch2_ops, 3429 }, 3430 }, 3431 }; 3432 3433 static struct clk_branch gcc_gpu_iref_en = { 3434 .halt_reg = 0x8c014, 3435 .halt_check = BRANCH_HALT, 3436 .clkr = { 3437 .enable_reg = 0x8c014, 3438 .enable_mask = BIT(0), 3439 .hw.init = &(const struct clk_init_data) { 3440 .name = "gcc_gpu_iref_en", 3441 .ops = &clk_branch2_ops, 3442 }, 3443 }, 3444 }; 3445 3446 static struct clk_branch gcc_gpu_memnoc_gfx_clk = { 3447 .halt_reg = 0x71010, 3448 .halt_check = BRANCH_HALT_VOTED, 3449 .hwcg_reg = 0x71010, 3450 .hwcg_bit = 1, 3451 .clkr = { 3452 .enable_reg = 0x71010, 3453 .enable_mask = BIT(0), 3454 .hw.init = &(const struct clk_init_data) { 3455 .name = "gcc_gpu_memnoc_gfx_clk", 3456 .ops = &clk_branch2_aon_ops, 3457 }, 3458 }, 3459 }; 3460 3461 static struct clk_branch gcc_gpu_snoc_dvm_gfx_clk = { 3462 .halt_reg = 0x71020, 3463 .halt_check = BRANCH_HALT, 3464 .clkr = { 3465 .enable_reg = 0x71020, 3466 .enable_mask = BIT(0), 3467 .hw.init = &(const struct clk_init_data) { 3468 .name = "gcc_gpu_snoc_dvm_gfx_clk", 3469 .ops = &clk_branch2_aon_ops, 3470 }, 3471 }, 3472 }; 3473 3474 static struct clk_branch gcc_gpu_tcu_throttle_ahb_clk = { 3475 .halt_reg = 0x71008, 3476 .halt_check = BRANCH_HALT_VOTED, 3477 .hwcg_reg = 0x71008, 3478 .hwcg_bit = 1, 3479 .clkr = { 3480 .enable_reg = 0x71008, 3481 .enable_mask = BIT(0), 3482 .hw.init = &(const struct clk_init_data) { 3483 .name = "gcc_gpu_tcu_throttle_ahb_clk", 3484 .ops = &clk_branch2_ops, 3485 }, 3486 }, 3487 }; 3488 3489 static struct clk_branch gcc_gpu_tcu_throttle_clk = { 3490 .halt_reg = 0x71018, 3491 .halt_check = BRANCH_HALT_VOTED, 3492 .hwcg_reg = 0x71018, 3493 .hwcg_bit = 1, 3494 .clkr = { 3495 .enable_reg = 0x71018, 3496 .enable_mask = BIT(0), 3497 .hw.init = &(const struct clk_init_data) { 3498 .name = "gcc_gpu_tcu_throttle_clk", 3499 .ops = &clk_branch2_ops, 3500 }, 3501 }, 3502 }; 3503 3504 static struct clk_branch gcc_pcie0_phy_rchng_clk = { 3505 .halt_reg = 0xa4038, 3506 .halt_check = BRANCH_HALT_VOTED, 3507 .clkr = { 3508 .enable_reg = 0x52018, 3509 .enable_mask = BIT(11), 3510 .hw.init = &(const struct clk_init_data) { 3511 .name = "gcc_pcie0_phy_rchng_clk", 3512 .parent_hws = (const struct clk_hw*[]){ 3513 &gcc_pcie_0_phy_rchng_clk_src.clkr.hw, 3514 }, 3515 .num_parents = 1, 3516 .flags = CLK_SET_RATE_PARENT, 3517 .ops = &clk_branch2_ops, 3518 }, 3519 }, 3520 }; 3521 3522 static struct clk_branch gcc_pcie1_phy_rchng_clk = { 3523 .halt_reg = 0x8d038, 3524 .halt_check = BRANCH_HALT_VOTED, 3525 .clkr = { 3526 .enable_reg = 0x52000, 3527 .enable_mask = BIT(23), 3528 .hw.init = &(const struct clk_init_data) { 3529 .name = "gcc_pcie1_phy_rchng_clk", 3530 .parent_hws = (const struct clk_hw*[]){ 3531 &gcc_pcie_1_phy_rchng_clk_src.clkr.hw, 3532 }, 3533 .num_parents = 1, 3534 .flags = CLK_SET_RATE_PARENT, 3535 .ops = &clk_branch2_ops, 3536 }, 3537 }, 3538 }; 3539 3540 static struct clk_branch gcc_pcie2a_phy_rchng_clk = { 3541 .halt_reg = 0x9d040, 3542 .halt_check = BRANCH_HALT_VOTED, 3543 .clkr = { 3544 .enable_reg = 0x52010, 3545 .enable_mask = BIT(15), 3546 .hw.init = &(const struct clk_init_data) { 3547 .name = "gcc_pcie2a_phy_rchng_clk", 3548 .parent_hws = (const struct clk_hw*[]){ 3549 &gcc_pcie_2a_phy_rchng_clk_src.clkr.hw, 3550 }, 3551 .num_parents = 1, 3552 .flags = CLK_SET_RATE_PARENT, 3553 .ops = &clk_branch2_ops, 3554 }, 3555 }, 3556 }; 3557 3558 static struct clk_branch gcc_pcie2b_phy_rchng_clk = { 3559 .halt_reg = 0x9e040, 3560 .halt_check = BRANCH_HALT_VOTED, 3561 .clkr = { 3562 .enable_reg = 0x52010, 3563 .enable_mask = BIT(22), 3564 .hw.init = &(const struct clk_init_data) { 3565 .name = "gcc_pcie2b_phy_rchng_clk", 3566 .parent_hws = (const struct clk_hw*[]){ 3567 &gcc_pcie_2b_phy_rchng_clk_src.clkr.hw, 3568 }, 3569 .num_parents = 1, 3570 .flags = CLK_SET_RATE_PARENT, 3571 .ops = &clk_branch2_ops, 3572 }, 3573 }, 3574 }; 3575 3576 static struct clk_branch gcc_pcie3a_phy_rchng_clk = { 3577 .halt_reg = 0xa0040, 3578 .halt_check = BRANCH_HALT_VOTED, 3579 .clkr = { 3580 .enable_reg = 0x52010, 3581 .enable_mask = BIT(29), 3582 .hw.init = &(const struct clk_init_data) { 3583 .name = "gcc_pcie3a_phy_rchng_clk", 3584 .parent_hws = (const struct clk_hw*[]){ 3585 &gcc_pcie_3a_phy_rchng_clk_src.clkr.hw, 3586 }, 3587 .num_parents = 1, 3588 .flags = CLK_SET_RATE_PARENT, 3589 .ops = &clk_branch2_ops, 3590 }, 3591 }, 3592 }; 3593 3594 static struct clk_branch gcc_pcie3b_phy_rchng_clk = { 3595 .halt_reg = 0xa2040, 3596 .halt_check = BRANCH_HALT_VOTED, 3597 .clkr = { 3598 .enable_reg = 0x52018, 3599 .enable_mask = BIT(4), 3600 .hw.init = &(const struct clk_init_data) { 3601 .name = "gcc_pcie3b_phy_rchng_clk", 3602 .parent_hws = (const struct clk_hw*[]){ 3603 &gcc_pcie_3b_phy_rchng_clk_src.clkr.hw, 3604 }, 3605 .num_parents = 1, 3606 .flags = CLK_SET_RATE_PARENT, 3607 .ops = &clk_branch2_ops, 3608 }, 3609 }, 3610 }; 3611 3612 static struct clk_branch gcc_pcie4_phy_rchng_clk = { 3613 .halt_reg = 0x6b040, 3614 .halt_check = BRANCH_HALT_VOTED, 3615 .clkr = { 3616 .enable_reg = 0x52000, 3617 .enable_mask = BIT(22), 3618 .hw.init = &(const struct clk_init_data) { 3619 .name = "gcc_pcie4_phy_rchng_clk", 3620 .parent_hws = (const struct clk_hw*[]){ 3621 &gcc_pcie_4_phy_rchng_clk_src.clkr.hw, 3622 }, 3623 .num_parents = 1, 3624 .flags = CLK_SET_RATE_PARENT, 3625 .ops = &clk_branch2_ops, 3626 }, 3627 }, 3628 }; 3629 3630 static struct clk_branch gcc_pcie_0_aux_clk = { 3631 .halt_reg = 0xa4028, 3632 .halt_check = BRANCH_HALT_VOTED, 3633 .clkr = { 3634 .enable_reg = 0x52018, 3635 .enable_mask = BIT(9), 3636 .hw.init = &(const struct clk_init_data) { 3637 .name = "gcc_pcie_0_aux_clk", 3638 .parent_hws = (const struct clk_hw*[]){ 3639 &gcc_pcie_0_aux_clk_src.clkr.hw, 3640 }, 3641 .num_parents = 1, 3642 .flags = CLK_SET_RATE_PARENT, 3643 .ops = &clk_branch2_ops, 3644 }, 3645 }, 3646 }; 3647 3648 static struct clk_branch gcc_pcie_0_cfg_ahb_clk = { 3649 .halt_reg = 0xa4024, 3650 .halt_check = BRANCH_HALT_VOTED, 3651 .hwcg_reg = 0xa4024, 3652 .hwcg_bit = 1, 3653 .clkr = { 3654 .enable_reg = 0x52018, 3655 .enable_mask = BIT(8), 3656 .hw.init = &(const struct clk_init_data) { 3657 .name = "gcc_pcie_0_cfg_ahb_clk", 3658 .ops = &clk_branch2_ops, 3659 }, 3660 }, 3661 }; 3662 3663 static struct clk_branch gcc_pcie_0_mstr_axi_clk = { 3664 .halt_reg = 0xa401c, 3665 .halt_check = BRANCH_HALT_SKIP, 3666 .hwcg_reg = 0xa401c, 3667 .hwcg_bit = 1, 3668 .clkr = { 3669 .enable_reg = 0x52018, 3670 .enable_mask = BIT(7), 3671 .hw.init = &(const struct clk_init_data) { 3672 .name = "gcc_pcie_0_mstr_axi_clk", 3673 .ops = &clk_branch2_ops, 3674 }, 3675 }, 3676 }; 3677 3678 static struct clk_branch gcc_pcie_0_pipe_clk = { 3679 .halt_reg = 0xa4030, 3680 .halt_check = BRANCH_HALT_SKIP, 3681 .clkr = { 3682 .enable_reg = 0x52018, 3683 .enable_mask = BIT(10), 3684 .hw.init = &(const struct clk_init_data) { 3685 .name = "gcc_pcie_0_pipe_clk", 3686 .parent_hws = (const struct clk_hw*[]){ 3687 &gcc_usb4_phy_pcie_pipe_mux_clk_src.clkr.hw, 3688 }, 3689 .num_parents = 1, 3690 .flags = CLK_SET_RATE_PARENT, 3691 .ops = &clk_branch2_ops, 3692 }, 3693 }, 3694 }; 3695 3696 static struct clk_branch gcc_pcie_0_slv_axi_clk = { 3697 .halt_reg = 0xa4014, 3698 .halt_check = BRANCH_HALT_VOTED, 3699 .hwcg_reg = 0xa4014, 3700 .hwcg_bit = 1, 3701 .clkr = { 3702 .enable_reg = 0x52018, 3703 .enable_mask = BIT(6), 3704 .hw.init = &(const struct clk_init_data) { 3705 .name = "gcc_pcie_0_slv_axi_clk", 3706 .ops = &clk_branch2_ops, 3707 }, 3708 }, 3709 }; 3710 3711 static struct clk_branch gcc_pcie_0_slv_q2a_axi_clk = { 3712 .halt_reg = 0xa4010, 3713 .halt_check = BRANCH_HALT_VOTED, 3714 .clkr = { 3715 .enable_reg = 0x52018, 3716 .enable_mask = BIT(5), 3717 .hw.init = &(const struct clk_init_data) { 3718 .name = "gcc_pcie_0_slv_q2a_axi_clk", 3719 .ops = &clk_branch2_ops, 3720 }, 3721 }, 3722 }; 3723 3724 static struct clk_branch gcc_pcie_1_aux_clk = { 3725 .halt_reg = 0x8d028, 3726 .halt_check = BRANCH_HALT_VOTED, 3727 .clkr = { 3728 .enable_reg = 0x52000, 3729 .enable_mask = BIT(29), 3730 .hw.init = &(const struct clk_init_data) { 3731 .name = "gcc_pcie_1_aux_clk", 3732 .parent_hws = (const struct clk_hw*[]){ 3733 &gcc_pcie_1_aux_clk_src.clkr.hw, 3734 }, 3735 .num_parents = 1, 3736 .flags = CLK_SET_RATE_PARENT, 3737 .ops = &clk_branch2_ops, 3738 }, 3739 }, 3740 }; 3741 3742 static struct clk_branch gcc_pcie_1_cfg_ahb_clk = { 3743 .halt_reg = 0x8d024, 3744 .halt_check = BRANCH_HALT_VOTED, 3745 .hwcg_reg = 0x8d024, 3746 .hwcg_bit = 1, 3747 .clkr = { 3748 .enable_reg = 0x52000, 3749 .enable_mask = BIT(28), 3750 .hw.init = &(const struct clk_init_data) { 3751 .name = "gcc_pcie_1_cfg_ahb_clk", 3752 .ops = &clk_branch2_ops, 3753 }, 3754 }, 3755 }; 3756 3757 static struct clk_branch gcc_pcie_1_mstr_axi_clk = { 3758 .halt_reg = 0x8d01c, 3759 .halt_check = BRANCH_HALT_SKIP, 3760 .hwcg_reg = 0x8d01c, 3761 .hwcg_bit = 1, 3762 .clkr = { 3763 .enable_reg = 0x52000, 3764 .enable_mask = BIT(27), 3765 .hw.init = &(const struct clk_init_data) { 3766 .name = "gcc_pcie_1_mstr_axi_clk", 3767 .ops = &clk_branch2_ops, 3768 }, 3769 }, 3770 }; 3771 3772 static struct clk_branch gcc_pcie_1_pipe_clk = { 3773 .halt_reg = 0x8d030, 3774 .halt_check = BRANCH_HALT_SKIP, 3775 .clkr = { 3776 .enable_reg = 0x52000, 3777 .enable_mask = BIT(30), 3778 .hw.init = &(const struct clk_init_data) { 3779 .name = "gcc_pcie_1_pipe_clk", 3780 .parent_hws = (const struct clk_hw*[]){ 3781 &gcc_usb4_1_phy_pcie_pipe_mux_clk_src.clkr.hw, 3782 }, 3783 .num_parents = 1, 3784 .flags = CLK_SET_RATE_PARENT, 3785 .ops = &clk_branch2_ops, 3786 }, 3787 }, 3788 }; 3789 3790 static struct clk_branch gcc_pcie_1_slv_axi_clk = { 3791 .halt_reg = 0x8d014, 3792 .halt_check = BRANCH_HALT_VOTED, 3793 .hwcg_reg = 0x8d014, 3794 .hwcg_bit = 1, 3795 .clkr = { 3796 .enable_reg = 0x52000, 3797 .enable_mask = BIT(26), 3798 .hw.init = &(const struct clk_init_data) { 3799 .name = "gcc_pcie_1_slv_axi_clk", 3800 .ops = &clk_branch2_ops, 3801 }, 3802 }, 3803 }; 3804 3805 static struct clk_branch gcc_pcie_1_slv_q2a_axi_clk = { 3806 .halt_reg = 0x8d010, 3807 .halt_check = BRANCH_HALT_VOTED, 3808 .clkr = { 3809 .enable_reg = 0x52000, 3810 .enable_mask = BIT(25), 3811 .hw.init = &(const struct clk_init_data) { 3812 .name = "gcc_pcie_1_slv_q2a_axi_clk", 3813 .ops = &clk_branch2_ops, 3814 }, 3815 }, 3816 }; 3817 3818 static struct clk_branch gcc_pcie_2a2b_clkref_clk = { 3819 .halt_reg = 0x8c034, 3820 .halt_check = BRANCH_HALT, 3821 .clkr = { 3822 .enable_reg = 0x8c034, 3823 .enable_mask = BIT(0), 3824 .hw.init = &(const struct clk_init_data) { 3825 .name = "gcc_pcie_2a2b_clkref_clk", 3826 .ops = &clk_branch2_ops, 3827 }, 3828 }, 3829 }; 3830 3831 static struct clk_branch gcc_pcie_2a_aux_clk = { 3832 .halt_reg = 0x9d028, 3833 .halt_check = BRANCH_HALT_VOTED, 3834 .clkr = { 3835 .enable_reg = 0x52010, 3836 .enable_mask = BIT(13), 3837 .hw.init = &(const struct clk_init_data) { 3838 .name = "gcc_pcie_2a_aux_clk", 3839 .parent_hws = (const struct clk_hw*[]){ 3840 &gcc_pcie_2a_aux_clk_src.clkr.hw, 3841 }, 3842 .num_parents = 1, 3843 .flags = CLK_SET_RATE_PARENT, 3844 .ops = &clk_branch2_ops, 3845 }, 3846 }, 3847 }; 3848 3849 static struct clk_branch gcc_pcie_2a_cfg_ahb_clk = { 3850 .halt_reg = 0x9d024, 3851 .halt_check = BRANCH_HALT_VOTED, 3852 .hwcg_reg = 0x9d024, 3853 .hwcg_bit = 1, 3854 .clkr = { 3855 .enable_reg = 0x52010, 3856 .enable_mask = BIT(12), 3857 .hw.init = &(const struct clk_init_data) { 3858 .name = "gcc_pcie_2a_cfg_ahb_clk", 3859 .ops = &clk_branch2_ops, 3860 }, 3861 }, 3862 }; 3863 3864 static struct clk_branch gcc_pcie_2a_mstr_axi_clk = { 3865 .halt_reg = 0x9d01c, 3866 .halt_check = BRANCH_HALT_SKIP, 3867 .hwcg_reg = 0x9d01c, 3868 .hwcg_bit = 1, 3869 .clkr = { 3870 .enable_reg = 0x52010, 3871 .enable_mask = BIT(11), 3872 .hw.init = &(const struct clk_init_data) { 3873 .name = "gcc_pcie_2a_mstr_axi_clk", 3874 .ops = &clk_branch2_ops, 3875 }, 3876 }, 3877 }; 3878 3879 static struct clk_branch gcc_pcie_2a_pipe_clk = { 3880 .halt_reg = 0x9d030, 3881 .halt_check = BRANCH_HALT_SKIP, 3882 .clkr = { 3883 .enable_reg = 0x52010, 3884 .enable_mask = BIT(14), 3885 .hw.init = &(const struct clk_init_data) { 3886 .name = "gcc_pcie_2a_pipe_clk", 3887 .parent_hws = (const struct clk_hw*[]){ 3888 &gcc_pcie_2a_pipe_clk_src.clkr.hw, 3889 }, 3890 .num_parents = 1, 3891 .flags = CLK_SET_RATE_PARENT, 3892 .ops = &clk_branch2_ops, 3893 }, 3894 }, 3895 }; 3896 3897 static struct clk_branch gcc_pcie_2a_pipediv2_clk = { 3898 .halt_reg = 0x9d038, 3899 .halt_check = BRANCH_HALT_SKIP, 3900 .clkr = { 3901 .enable_reg = 0x52018, 3902 .enable_mask = BIT(22), 3903 .hw.init = &(const struct clk_init_data) { 3904 .name = "gcc_pcie_2a_pipediv2_clk", 3905 .parent_hws = (const struct clk_hw*[]){ 3906 &gcc_pcie_2a_pipe_div_clk_src.clkr.hw, 3907 }, 3908 .num_parents = 1, 3909 .flags = CLK_SET_RATE_PARENT, 3910 .ops = &clk_branch2_ops, 3911 }, 3912 }, 3913 }; 3914 3915 static struct clk_branch gcc_pcie_2a_slv_axi_clk = { 3916 .halt_reg = 0x9d014, 3917 .halt_check = BRANCH_HALT_VOTED, 3918 .hwcg_reg = 0x9d014, 3919 .hwcg_bit = 1, 3920 .clkr = { 3921 .enable_reg = 0x52010, 3922 .enable_mask = BIT(10), 3923 .hw.init = &(const struct clk_init_data) { 3924 .name = "gcc_pcie_2a_slv_axi_clk", 3925 .ops = &clk_branch2_ops, 3926 }, 3927 }, 3928 }; 3929 3930 static struct clk_branch gcc_pcie_2a_slv_q2a_axi_clk = { 3931 .halt_reg = 0x9d010, 3932 .halt_check = BRANCH_HALT_VOTED, 3933 .clkr = { 3934 .enable_reg = 0x52018, 3935 .enable_mask = BIT(12), 3936 .hw.init = &(const struct clk_init_data) { 3937 .name = "gcc_pcie_2a_slv_q2a_axi_clk", 3938 .ops = &clk_branch2_ops, 3939 }, 3940 }, 3941 }; 3942 3943 static struct clk_branch gcc_pcie_2b_aux_clk = { 3944 .halt_reg = 0x9e028, 3945 .halt_check = BRANCH_HALT_VOTED, 3946 .clkr = { 3947 .enable_reg = 0x52010, 3948 .enable_mask = BIT(20), 3949 .hw.init = &(const struct clk_init_data) { 3950 .name = "gcc_pcie_2b_aux_clk", 3951 .parent_hws = (const struct clk_hw*[]){ 3952 &gcc_pcie_2b_aux_clk_src.clkr.hw, 3953 }, 3954 .num_parents = 1, 3955 .flags = CLK_SET_RATE_PARENT, 3956 .ops = &clk_branch2_ops, 3957 }, 3958 }, 3959 }; 3960 3961 static struct clk_branch gcc_pcie_2b_cfg_ahb_clk = { 3962 .halt_reg = 0x9e024, 3963 .halt_check = BRANCH_HALT_VOTED, 3964 .hwcg_reg = 0x9e024, 3965 .hwcg_bit = 1, 3966 .clkr = { 3967 .enable_reg = 0x52010, 3968 .enable_mask = BIT(19), 3969 .hw.init = &(const struct clk_init_data) { 3970 .name = "gcc_pcie_2b_cfg_ahb_clk", 3971 .ops = &clk_branch2_ops, 3972 }, 3973 }, 3974 }; 3975 3976 static struct clk_branch gcc_pcie_2b_mstr_axi_clk = { 3977 .halt_reg = 0x9e01c, 3978 .halt_check = BRANCH_HALT_SKIP, 3979 .hwcg_reg = 0x9e01c, 3980 .hwcg_bit = 1, 3981 .clkr = { 3982 .enable_reg = 0x52010, 3983 .enable_mask = BIT(18), 3984 .hw.init = &(const struct clk_init_data) { 3985 .name = "gcc_pcie_2b_mstr_axi_clk", 3986 .ops = &clk_branch2_ops, 3987 }, 3988 }, 3989 }; 3990 3991 static struct clk_branch gcc_pcie_2b_pipe_clk = { 3992 .halt_reg = 0x9e030, 3993 .halt_check = BRANCH_HALT_SKIP, 3994 .clkr = { 3995 .enable_reg = 0x52010, 3996 .enable_mask = BIT(21), 3997 .hw.init = &(const struct clk_init_data) { 3998 .name = "gcc_pcie_2b_pipe_clk", 3999 .parent_hws = (const struct clk_hw*[]){ 4000 &gcc_pcie_2b_pipe_clk_src.clkr.hw, 4001 }, 4002 .num_parents = 1, 4003 .flags = CLK_SET_RATE_PARENT, 4004 .ops = &clk_branch2_ops, 4005 }, 4006 }, 4007 }; 4008 4009 static struct clk_branch gcc_pcie_2b_pipediv2_clk = { 4010 .halt_reg = 0x9e038, 4011 .halt_check = BRANCH_HALT_SKIP, 4012 .clkr = { 4013 .enable_reg = 0x52018, 4014 .enable_mask = BIT(23), 4015 .hw.init = &(const struct clk_init_data) { 4016 .name = "gcc_pcie_2b_pipediv2_clk", 4017 .parent_hws = (const struct clk_hw*[]){ 4018 &gcc_pcie_2b_pipe_div_clk_src.clkr.hw, 4019 }, 4020 .num_parents = 1, 4021 .flags = CLK_SET_RATE_PARENT, 4022 .ops = &clk_branch2_ops, 4023 }, 4024 }, 4025 }; 4026 4027 static struct clk_branch gcc_pcie_2b_slv_axi_clk = { 4028 .halt_reg = 0x9e014, 4029 .halt_check = BRANCH_HALT_VOTED, 4030 .hwcg_reg = 0x9e014, 4031 .hwcg_bit = 1, 4032 .clkr = { 4033 .enable_reg = 0x52010, 4034 .enable_mask = BIT(17), 4035 .hw.init = &(const struct clk_init_data) { 4036 .name = "gcc_pcie_2b_slv_axi_clk", 4037 .ops = &clk_branch2_ops, 4038 }, 4039 }, 4040 }; 4041 4042 static struct clk_branch gcc_pcie_2b_slv_q2a_axi_clk = { 4043 .halt_reg = 0x9e010, 4044 .halt_check = BRANCH_HALT_VOTED, 4045 .clkr = { 4046 .enable_reg = 0x52010, 4047 .enable_mask = BIT(16), 4048 .hw.init = &(const struct clk_init_data) { 4049 .name = "gcc_pcie_2b_slv_q2a_axi_clk", 4050 .ops = &clk_branch2_ops, 4051 }, 4052 }, 4053 }; 4054 4055 static struct clk_branch gcc_pcie_3a3b_clkref_clk = { 4056 .halt_reg = 0x8c038, 4057 .halt_check = BRANCH_HALT, 4058 .clkr = { 4059 .enable_reg = 0x8c038, 4060 .enable_mask = BIT(0), 4061 .hw.init = &(const struct clk_init_data) { 4062 .name = "gcc_pcie_3a3b_clkref_clk", 4063 .ops = &clk_branch2_ops, 4064 }, 4065 }, 4066 }; 4067 4068 static struct clk_branch gcc_pcie_3a_aux_clk = { 4069 .halt_reg = 0xa0028, 4070 .halt_check = BRANCH_HALT_VOTED, 4071 .clkr = { 4072 .enable_reg = 0x52010, 4073 .enable_mask = BIT(27), 4074 .hw.init = &(const struct clk_init_data) { 4075 .name = "gcc_pcie_3a_aux_clk", 4076 .parent_hws = (const struct clk_hw*[]){ 4077 &gcc_pcie_3a_aux_clk_src.clkr.hw, 4078 }, 4079 .num_parents = 1, 4080 .flags = CLK_SET_RATE_PARENT, 4081 .ops = &clk_branch2_ops, 4082 }, 4083 }, 4084 }; 4085 4086 static struct clk_branch gcc_pcie_3a_cfg_ahb_clk = { 4087 .halt_reg = 0xa0024, 4088 .halt_check = BRANCH_HALT_VOTED, 4089 .hwcg_reg = 0xa0024, 4090 .hwcg_bit = 1, 4091 .clkr = { 4092 .enable_reg = 0x52010, 4093 .enable_mask = BIT(26), 4094 .hw.init = &(const struct clk_init_data) { 4095 .name = "gcc_pcie_3a_cfg_ahb_clk", 4096 .ops = &clk_branch2_ops, 4097 }, 4098 }, 4099 }; 4100 4101 static struct clk_branch gcc_pcie_3a_mstr_axi_clk = { 4102 .halt_reg = 0xa001c, 4103 .halt_check = BRANCH_HALT_SKIP, 4104 .hwcg_reg = 0xa001c, 4105 .hwcg_bit = 1, 4106 .clkr = { 4107 .enable_reg = 0x52010, 4108 .enable_mask = BIT(25), 4109 .hw.init = &(const struct clk_init_data) { 4110 .name = "gcc_pcie_3a_mstr_axi_clk", 4111 .ops = &clk_branch2_ops, 4112 }, 4113 }, 4114 }; 4115 4116 static struct clk_branch gcc_pcie_3a_pipe_clk = { 4117 .halt_reg = 0xa0030, 4118 .halt_check = BRANCH_HALT_SKIP, 4119 .clkr = { 4120 .enable_reg = 0x52010, 4121 .enable_mask = BIT(28), 4122 .hw.init = &(const struct clk_init_data) { 4123 .name = "gcc_pcie_3a_pipe_clk", 4124 .parent_hws = (const struct clk_hw*[]){ 4125 &gcc_pcie_3a_pipe_clk_src.clkr.hw, 4126 }, 4127 .num_parents = 1, 4128 .flags = CLK_SET_RATE_PARENT, 4129 .ops = &clk_branch2_ops, 4130 }, 4131 }, 4132 }; 4133 4134 static struct clk_branch gcc_pcie_3a_pipediv2_clk = { 4135 .halt_reg = 0xa0038, 4136 .halt_check = BRANCH_HALT_SKIP, 4137 .clkr = { 4138 .enable_reg = 0x52018, 4139 .enable_mask = BIT(24), 4140 .hw.init = &(const struct clk_init_data) { 4141 .name = "gcc_pcie_3a_pipediv2_clk", 4142 .parent_hws = (const struct clk_hw*[]){ 4143 &gcc_pcie_3a_pipe_div_clk_src.clkr.hw, 4144 }, 4145 .num_parents = 1, 4146 .flags = CLK_SET_RATE_PARENT, 4147 .ops = &clk_branch2_ops, 4148 }, 4149 }, 4150 }; 4151 4152 static struct clk_branch gcc_pcie_3a_slv_axi_clk = { 4153 .halt_reg = 0xa0014, 4154 .halt_check = BRANCH_HALT_VOTED, 4155 .hwcg_reg = 0xa0014, 4156 .hwcg_bit = 1, 4157 .clkr = { 4158 .enable_reg = 0x52010, 4159 .enable_mask = BIT(24), 4160 .hw.init = &(const struct clk_init_data) { 4161 .name = "gcc_pcie_3a_slv_axi_clk", 4162 .ops = &clk_branch2_ops, 4163 }, 4164 }, 4165 }; 4166 4167 static struct clk_branch gcc_pcie_3a_slv_q2a_axi_clk = { 4168 .halt_reg = 0xa0010, 4169 .halt_check = BRANCH_HALT_VOTED, 4170 .clkr = { 4171 .enable_reg = 0x52010, 4172 .enable_mask = BIT(23), 4173 .hw.init = &(const struct clk_init_data) { 4174 .name = "gcc_pcie_3a_slv_q2a_axi_clk", 4175 .ops = &clk_branch2_ops, 4176 }, 4177 }, 4178 }; 4179 4180 static struct clk_branch gcc_pcie_3b_aux_clk = { 4181 .halt_reg = 0xa2028, 4182 .halt_check = BRANCH_HALT_VOTED, 4183 .clkr = { 4184 .enable_reg = 0x52018, 4185 .enable_mask = BIT(2), 4186 .hw.init = &(const struct clk_init_data) { 4187 .name = "gcc_pcie_3b_aux_clk", 4188 .parent_hws = (const struct clk_hw*[]){ 4189 &gcc_pcie_3b_aux_clk_src.clkr.hw, 4190 }, 4191 .num_parents = 1, 4192 .flags = CLK_SET_RATE_PARENT, 4193 .ops = &clk_branch2_ops, 4194 }, 4195 }, 4196 }; 4197 4198 static struct clk_branch gcc_pcie_3b_cfg_ahb_clk = { 4199 .halt_reg = 0xa2024, 4200 .halt_check = BRANCH_HALT_VOTED, 4201 .hwcg_reg = 0xa2024, 4202 .hwcg_bit = 1, 4203 .clkr = { 4204 .enable_reg = 0x52018, 4205 .enable_mask = BIT(1), 4206 .hw.init = &(const struct clk_init_data) { 4207 .name = "gcc_pcie_3b_cfg_ahb_clk", 4208 .ops = &clk_branch2_ops, 4209 }, 4210 }, 4211 }; 4212 4213 static struct clk_branch gcc_pcie_3b_mstr_axi_clk = { 4214 .halt_reg = 0xa201c, 4215 .halt_check = BRANCH_HALT_SKIP, 4216 .hwcg_reg = 0xa201c, 4217 .hwcg_bit = 1, 4218 .clkr = { 4219 .enable_reg = 0x52018, 4220 .enable_mask = BIT(0), 4221 .hw.init = &(const struct clk_init_data) { 4222 .name = "gcc_pcie_3b_mstr_axi_clk", 4223 .ops = &clk_branch2_ops, 4224 }, 4225 }, 4226 }; 4227 4228 static struct clk_branch gcc_pcie_3b_pipe_clk = { 4229 .halt_reg = 0xa2030, 4230 .halt_check = BRANCH_HALT_SKIP, 4231 .clkr = { 4232 .enable_reg = 0x52018, 4233 .enable_mask = BIT(3), 4234 .hw.init = &(const struct clk_init_data) { 4235 .name = "gcc_pcie_3b_pipe_clk", 4236 .parent_hws = (const struct clk_hw*[]){ 4237 &gcc_pcie_3b_pipe_clk_src.clkr.hw, 4238 }, 4239 .num_parents = 1, 4240 .flags = CLK_SET_RATE_PARENT, 4241 .ops = &clk_branch2_ops, 4242 }, 4243 }, 4244 }; 4245 4246 static struct clk_branch gcc_pcie_3b_pipediv2_clk = { 4247 .halt_reg = 0xa2038, 4248 .halt_check = BRANCH_HALT_SKIP, 4249 .clkr = { 4250 .enable_reg = 0x52018, 4251 .enable_mask = BIT(25), 4252 .hw.init = &(const struct clk_init_data) { 4253 .name = "gcc_pcie_3b_pipediv2_clk", 4254 .parent_hws = (const struct clk_hw*[]){ 4255 &gcc_pcie_3b_pipe_div_clk_src.clkr.hw, 4256 }, 4257 .num_parents = 1, 4258 .flags = CLK_SET_RATE_PARENT, 4259 .ops = &clk_branch2_ops, 4260 }, 4261 }, 4262 }; 4263 4264 static struct clk_branch gcc_pcie_3b_slv_axi_clk = { 4265 .halt_reg = 0xa2014, 4266 .halt_check = BRANCH_HALT_VOTED, 4267 .hwcg_reg = 0xa2014, 4268 .hwcg_bit = 1, 4269 .clkr = { 4270 .enable_reg = 0x52010, 4271 .enable_mask = BIT(31), 4272 .hw.init = &(const struct clk_init_data) { 4273 .name = "gcc_pcie_3b_slv_axi_clk", 4274 .ops = &clk_branch2_ops, 4275 }, 4276 }, 4277 }; 4278 4279 static struct clk_branch gcc_pcie_3b_slv_q2a_axi_clk = { 4280 .halt_reg = 0xa2010, 4281 .halt_check = BRANCH_HALT_VOTED, 4282 .clkr = { 4283 .enable_reg = 0x52010, 4284 .enable_mask = BIT(30), 4285 .hw.init = &(const struct clk_init_data) { 4286 .name = "gcc_pcie_3b_slv_q2a_axi_clk", 4287 .ops = &clk_branch2_ops, 4288 }, 4289 }, 4290 }; 4291 4292 static struct clk_branch gcc_pcie_4_aux_clk = { 4293 .halt_reg = 0x6b028, 4294 .halt_check = BRANCH_HALT_VOTED, 4295 .clkr = { 4296 .enable_reg = 0x52008, 4297 .enable_mask = BIT(3), 4298 .hw.init = &(const struct clk_init_data) { 4299 .name = "gcc_pcie_4_aux_clk", 4300 .parent_hws = (const struct clk_hw*[]){ 4301 &gcc_pcie_4_aux_clk_src.clkr.hw, 4302 }, 4303 .num_parents = 1, 4304 .flags = CLK_SET_RATE_PARENT, 4305 .ops = &clk_branch2_ops, 4306 }, 4307 }, 4308 }; 4309 4310 static struct clk_branch gcc_pcie_4_cfg_ahb_clk = { 4311 .halt_reg = 0x6b024, 4312 .halt_check = BRANCH_HALT_VOTED, 4313 .hwcg_reg = 0x6b024, 4314 .hwcg_bit = 1, 4315 .clkr = { 4316 .enable_reg = 0x52008, 4317 .enable_mask = BIT(2), 4318 .hw.init = &(const struct clk_init_data) { 4319 .name = "gcc_pcie_4_cfg_ahb_clk", 4320 .ops = &clk_branch2_ops, 4321 }, 4322 }, 4323 }; 4324 4325 static struct clk_branch gcc_pcie_4_clkref_clk = { 4326 .halt_reg = 0x8c030, 4327 .halt_check = BRANCH_HALT, 4328 .clkr = { 4329 .enable_reg = 0x8c030, 4330 .enable_mask = BIT(0), 4331 .hw.init = &(const struct clk_init_data) { 4332 .name = "gcc_pcie_4_clkref_clk", 4333 .ops = &clk_branch2_ops, 4334 }, 4335 }, 4336 }; 4337 4338 static struct clk_branch gcc_pcie_4_mstr_axi_clk = { 4339 .halt_reg = 0x6b01c, 4340 .halt_check = BRANCH_HALT_SKIP, 4341 .hwcg_reg = 0x6b01c, 4342 .hwcg_bit = 1, 4343 .clkr = { 4344 .enable_reg = 0x52008, 4345 .enable_mask = BIT(1), 4346 .hw.init = &(const struct clk_init_data) { 4347 .name = "gcc_pcie_4_mstr_axi_clk", 4348 .ops = &clk_branch2_ops, 4349 }, 4350 }, 4351 }; 4352 4353 static struct clk_branch gcc_pcie_4_pipe_clk = { 4354 .halt_reg = 0x6b030, 4355 .halt_check = BRANCH_HALT_SKIP, 4356 .clkr = { 4357 .enable_reg = 0x52008, 4358 .enable_mask = BIT(4), 4359 .hw.init = &(const struct clk_init_data) { 4360 .name = "gcc_pcie_4_pipe_clk", 4361 .parent_hws = (const struct clk_hw*[]){ 4362 &gcc_pcie_4_pipe_clk_src.clkr.hw, 4363 }, 4364 .num_parents = 1, 4365 .flags = CLK_SET_RATE_PARENT, 4366 .ops = &clk_branch2_ops, 4367 }, 4368 }, 4369 }; 4370 4371 static struct clk_branch gcc_pcie_4_pipediv2_clk = { 4372 .halt_reg = 0x6b038, 4373 .halt_check = BRANCH_HALT_SKIP, 4374 .clkr = { 4375 .enable_reg = 0x52018, 4376 .enable_mask = BIT(16), 4377 .hw.init = &(const struct clk_init_data) { 4378 .name = "gcc_pcie_4_pipediv2_clk", 4379 .parent_hws = (const struct clk_hw*[]){ 4380 &gcc_pcie_4_pipe_div_clk_src.clkr.hw, 4381 }, 4382 .num_parents = 1, 4383 .flags = CLK_SET_RATE_PARENT, 4384 .ops = &clk_branch2_ops, 4385 }, 4386 }, 4387 }; 4388 4389 static struct clk_branch gcc_pcie_4_slv_axi_clk = { 4390 .halt_reg = 0x6b014, 4391 .halt_check = BRANCH_HALT_VOTED, 4392 .hwcg_reg = 0x6b014, 4393 .hwcg_bit = 1, 4394 .clkr = { 4395 .enable_reg = 0x52008, 4396 .enable_mask = BIT(0), 4397 .hw.init = &(const struct clk_init_data) { 4398 .name = "gcc_pcie_4_slv_axi_clk", 4399 .ops = &clk_branch2_ops, 4400 }, 4401 }, 4402 }; 4403 4404 static struct clk_branch gcc_pcie_4_slv_q2a_axi_clk = { 4405 .halt_reg = 0x6b010, 4406 .halt_check = BRANCH_HALT_VOTED, 4407 .clkr = { 4408 .enable_reg = 0x52008, 4409 .enable_mask = BIT(5), 4410 .hw.init = &(const struct clk_init_data) { 4411 .name = "gcc_pcie_4_slv_q2a_axi_clk", 4412 .ops = &clk_branch2_ops, 4413 }, 4414 }, 4415 }; 4416 4417 static struct clk_branch gcc_pcie_rscc_ahb_clk = { 4418 .halt_reg = 0xae008, 4419 .halt_check = BRANCH_HALT_VOTED, 4420 .hwcg_reg = 0xae008, 4421 .hwcg_bit = 1, 4422 .clkr = { 4423 .enable_reg = 0x52020, 4424 .enable_mask = BIT(17), 4425 .hw.init = &(const struct clk_init_data) { 4426 .name = "gcc_pcie_rscc_ahb_clk", 4427 .ops = &clk_branch2_ops, 4428 }, 4429 }, 4430 }; 4431 4432 static struct clk_branch gcc_pcie_rscc_xo_clk = { 4433 .halt_reg = 0xae004, 4434 .halt_check = BRANCH_HALT_VOTED, 4435 .clkr = { 4436 .enable_reg = 0x52020, 4437 .enable_mask = BIT(16), 4438 .hw.init = &(const struct clk_init_data) { 4439 .name = "gcc_pcie_rscc_xo_clk", 4440 .parent_hws = (const struct clk_hw*[]){ 4441 &gcc_pcie_rscc_xo_clk_src.clkr.hw, 4442 }, 4443 .num_parents = 1, 4444 .flags = CLK_SET_RATE_PARENT, 4445 .ops = &clk_branch2_ops, 4446 }, 4447 }, 4448 }; 4449 4450 static struct clk_branch gcc_pcie_throttle_cfg_clk = { 4451 .halt_reg = 0xa6028, 4452 .halt_check = BRANCH_HALT_VOTED, 4453 .clkr = { 4454 .enable_reg = 0x52020, 4455 .enable_mask = BIT(15), 4456 .hw.init = &(const struct clk_init_data) { 4457 .name = "gcc_pcie_throttle_cfg_clk", 4458 .ops = &clk_branch2_ops, 4459 }, 4460 }, 4461 }; 4462 4463 static struct clk_branch gcc_pdm2_clk = { 4464 .halt_reg = 0x3300c, 4465 .halt_check = BRANCH_HALT, 4466 .clkr = { 4467 .enable_reg = 0x3300c, 4468 .enable_mask = BIT(0), 4469 .hw.init = &(const struct clk_init_data) { 4470 .name = "gcc_pdm2_clk", 4471 .parent_hws = (const struct clk_hw*[]){ 4472 &gcc_pdm2_clk_src.clkr.hw, 4473 }, 4474 .num_parents = 1, 4475 .flags = CLK_SET_RATE_PARENT, 4476 .ops = &clk_branch2_ops, 4477 }, 4478 }, 4479 }; 4480 4481 static struct clk_branch gcc_pdm_ahb_clk = { 4482 .halt_reg = 0x33004, 4483 .halt_check = BRANCH_HALT_VOTED, 4484 .hwcg_reg = 0x33004, 4485 .hwcg_bit = 1, 4486 .clkr = { 4487 .enable_reg = 0x33004, 4488 .enable_mask = BIT(0), 4489 .hw.init = &(const struct clk_init_data) { 4490 .name = "gcc_pdm_ahb_clk", 4491 .ops = &clk_branch2_ops, 4492 }, 4493 }, 4494 }; 4495 4496 static struct clk_branch gcc_pdm_xo4_clk = { 4497 .halt_reg = 0x33008, 4498 .halt_check = BRANCH_HALT, 4499 .clkr = { 4500 .enable_reg = 0x33008, 4501 .enable_mask = BIT(0), 4502 .hw.init = &(const struct clk_init_data) { 4503 .name = "gcc_pdm_xo4_clk", 4504 .ops = &clk_branch2_ops, 4505 }, 4506 }, 4507 }; 4508 4509 static struct clk_branch gcc_qmip_camera_nrt_ahb_clk = { 4510 .halt_reg = 0x26008, 4511 .halt_check = BRANCH_HALT_VOTED, 4512 .hwcg_reg = 0x26008, 4513 .hwcg_bit = 1, 4514 .clkr = { 4515 .enable_reg = 0x26008, 4516 .enable_mask = BIT(0), 4517 .hw.init = &(const struct clk_init_data) { 4518 .name = "gcc_qmip_camera_nrt_ahb_clk", 4519 .ops = &clk_branch2_ops, 4520 }, 4521 }, 4522 }; 4523 4524 static struct clk_branch gcc_qmip_camera_rt_ahb_clk = { 4525 .halt_reg = 0x2600c, 4526 .halt_check = BRANCH_HALT_VOTED, 4527 .hwcg_reg = 0x2600c, 4528 .hwcg_bit = 1, 4529 .clkr = { 4530 .enable_reg = 0x2600c, 4531 .enable_mask = BIT(0), 4532 .hw.init = &(const struct clk_init_data) { 4533 .name = "gcc_qmip_camera_rt_ahb_clk", 4534 .ops = &clk_branch2_ops, 4535 }, 4536 }, 4537 }; 4538 4539 static struct clk_branch gcc_qmip_disp1_ahb_clk = { 4540 .halt_reg = 0xbb008, 4541 .halt_check = BRANCH_HALT_VOTED, 4542 .hwcg_reg = 0xbb008, 4543 .hwcg_bit = 1, 4544 .clkr = { 4545 .enable_reg = 0xbb008, 4546 .enable_mask = BIT(0), 4547 .hw.init = &(const struct clk_init_data) { 4548 .name = "gcc_qmip_disp1_ahb_clk", 4549 .ops = &clk_branch2_ops, 4550 }, 4551 }, 4552 }; 4553 4554 static struct clk_branch gcc_qmip_disp1_rot_ahb_clk = { 4555 .halt_reg = 0xbb00c, 4556 .halt_check = BRANCH_HALT_VOTED, 4557 .hwcg_reg = 0xbb00c, 4558 .hwcg_bit = 1, 4559 .clkr = { 4560 .enable_reg = 0xbb00c, 4561 .enable_mask = BIT(0), 4562 .hw.init = &(const struct clk_init_data) { 4563 .name = "gcc_qmip_disp1_rot_ahb_clk", 4564 .ops = &clk_branch2_ops, 4565 }, 4566 }, 4567 }; 4568 4569 static struct clk_branch gcc_qmip_disp_ahb_clk = { 4570 .halt_reg = 0x27008, 4571 .halt_check = BRANCH_HALT_VOTED, 4572 .hwcg_reg = 0x27008, 4573 .hwcg_bit = 1, 4574 .clkr = { 4575 .enable_reg = 0x27008, 4576 .enable_mask = BIT(0), 4577 .hw.init = &(const struct clk_init_data) { 4578 .name = "gcc_qmip_disp_ahb_clk", 4579 .ops = &clk_branch2_ops, 4580 }, 4581 }, 4582 }; 4583 4584 static struct clk_branch gcc_qmip_disp_rot_ahb_clk = { 4585 .halt_reg = 0x2700c, 4586 .halt_check = BRANCH_HALT_VOTED, 4587 .hwcg_reg = 0x2700c, 4588 .hwcg_bit = 1, 4589 .clkr = { 4590 .enable_reg = 0x2700c, 4591 .enable_mask = BIT(0), 4592 .hw.init = &(const struct clk_init_data) { 4593 .name = "gcc_qmip_disp_rot_ahb_clk", 4594 .ops = &clk_branch2_ops, 4595 }, 4596 }, 4597 }; 4598 4599 static struct clk_branch gcc_qmip_video_cvp_ahb_clk = { 4600 .halt_reg = 0x28008, 4601 .halt_check = BRANCH_HALT_VOTED, 4602 .hwcg_reg = 0x28008, 4603 .hwcg_bit = 1, 4604 .clkr = { 4605 .enable_reg = 0x28008, 4606 .enable_mask = BIT(0), 4607 .hw.init = &(const struct clk_init_data) { 4608 .name = "gcc_qmip_video_cvp_ahb_clk", 4609 .ops = &clk_branch2_ops, 4610 }, 4611 }, 4612 }; 4613 4614 static struct clk_branch gcc_qmip_video_vcodec_ahb_clk = { 4615 .halt_reg = 0x2800c, 4616 .halt_check = BRANCH_HALT_VOTED, 4617 .hwcg_reg = 0x2800c, 4618 .hwcg_bit = 1, 4619 .clkr = { 4620 .enable_reg = 0x2800c, 4621 .enable_mask = BIT(0), 4622 .hw.init = &(const struct clk_init_data) { 4623 .name = "gcc_qmip_video_vcodec_ahb_clk", 4624 .ops = &clk_branch2_ops, 4625 }, 4626 }, 4627 }; 4628 4629 static struct clk_branch gcc_qupv3_wrap0_core_2x_clk = { 4630 .halt_reg = 0x17014, 4631 .halt_check = BRANCH_HALT_VOTED, 4632 .clkr = { 4633 .enable_reg = 0x52008, 4634 .enable_mask = BIT(9), 4635 .hw.init = &(const struct clk_init_data) { 4636 .name = "gcc_qupv3_wrap0_core_2x_clk", 4637 .ops = &clk_branch2_ops, 4638 }, 4639 }, 4640 }; 4641 4642 static struct clk_branch gcc_qupv3_wrap0_core_clk = { 4643 .halt_reg = 0x1700c, 4644 .halt_check = BRANCH_HALT_VOTED, 4645 .clkr = { 4646 .enable_reg = 0x52008, 4647 .enable_mask = BIT(8), 4648 .hw.init = &(const struct clk_init_data) { 4649 .name = "gcc_qupv3_wrap0_core_clk", 4650 .ops = &clk_branch2_ops, 4651 }, 4652 }, 4653 }; 4654 4655 static struct clk_branch gcc_qupv3_wrap0_qspi0_clk = { 4656 .halt_reg = 0x17ac4, 4657 .halt_check = BRANCH_HALT_VOTED, 4658 .clkr = { 4659 .enable_reg = 0x52020, 4660 .enable_mask = BIT(0), 4661 .hw.init = &(const struct clk_init_data) { 4662 .name = "gcc_qupv3_wrap0_qspi0_clk", 4663 .parent_hws = (const struct clk_hw*[]){ 4664 &gcc_qupv3_wrap0_s4_clk_src.clkr.hw, 4665 }, 4666 .num_parents = 1, 4667 .flags = CLK_SET_RATE_PARENT, 4668 .ops = &clk_branch2_ops, 4669 }, 4670 }, 4671 }; 4672 4673 static struct clk_branch gcc_qupv3_wrap0_s0_clk = { 4674 .halt_reg = 0x17144, 4675 .halt_check = BRANCH_HALT_VOTED, 4676 .clkr = { 4677 .enable_reg = 0x52008, 4678 .enable_mask = BIT(10), 4679 .hw.init = &(const struct clk_init_data) { 4680 .name = "gcc_qupv3_wrap0_s0_clk", 4681 .parent_hws = (const struct clk_hw*[]){ 4682 &gcc_qupv3_wrap0_s0_clk_src.clkr.hw, 4683 }, 4684 .num_parents = 1, 4685 .flags = CLK_SET_RATE_PARENT, 4686 .ops = &clk_branch2_ops, 4687 }, 4688 }, 4689 }; 4690 4691 static struct clk_branch gcc_qupv3_wrap0_s1_clk = { 4692 .halt_reg = 0x17274, 4693 .halt_check = BRANCH_HALT_VOTED, 4694 .clkr = { 4695 .enable_reg = 0x52008, 4696 .enable_mask = BIT(11), 4697 .hw.init = &(const struct clk_init_data) { 4698 .name = "gcc_qupv3_wrap0_s1_clk", 4699 .parent_hws = (const struct clk_hw*[]){ 4700 &gcc_qupv3_wrap0_s1_clk_src.clkr.hw, 4701 }, 4702 .num_parents = 1, 4703 .flags = CLK_SET_RATE_PARENT, 4704 .ops = &clk_branch2_ops, 4705 }, 4706 }, 4707 }; 4708 4709 static struct clk_branch gcc_qupv3_wrap0_s2_clk = { 4710 .halt_reg = 0x173a4, 4711 .halt_check = BRANCH_HALT_VOTED, 4712 .clkr = { 4713 .enable_reg = 0x52008, 4714 .enable_mask = BIT(12), 4715 .hw.init = &(const struct clk_init_data) { 4716 .name = "gcc_qupv3_wrap0_s2_clk", 4717 .parent_hws = (const struct clk_hw*[]){ 4718 &gcc_qupv3_wrap0_s2_clk_src.clkr.hw, 4719 }, 4720 .num_parents = 1, 4721 .flags = CLK_SET_RATE_PARENT, 4722 .ops = &clk_branch2_ops, 4723 }, 4724 }, 4725 }; 4726 4727 static struct clk_branch gcc_qupv3_wrap0_s3_clk = { 4728 .halt_reg = 0x174d4, 4729 .halt_check = BRANCH_HALT_VOTED, 4730 .clkr = { 4731 .enable_reg = 0x52008, 4732 .enable_mask = BIT(13), 4733 .hw.init = &(const struct clk_init_data) { 4734 .name = "gcc_qupv3_wrap0_s3_clk", 4735 .parent_hws = (const struct clk_hw*[]){ 4736 &gcc_qupv3_wrap0_s3_clk_src.clkr.hw, 4737 }, 4738 .num_parents = 1, 4739 .flags = CLK_SET_RATE_PARENT, 4740 .ops = &clk_branch2_ops, 4741 }, 4742 }, 4743 }; 4744 4745 static struct clk_branch gcc_qupv3_wrap0_s4_clk = { 4746 .halt_reg = 0x17604, 4747 .halt_check = BRANCH_HALT_VOTED, 4748 .clkr = { 4749 .enable_reg = 0x52008, 4750 .enable_mask = BIT(14), 4751 .hw.init = &(const struct clk_init_data) { 4752 .name = "gcc_qupv3_wrap0_s4_clk", 4753 .parent_hws = (const struct clk_hw*[]){ 4754 &gcc_qupv3_wrap0_s4_div_clk_src.clkr.hw, 4755 }, 4756 .num_parents = 1, 4757 .flags = CLK_SET_RATE_PARENT, 4758 .ops = &clk_branch2_ops, 4759 }, 4760 }, 4761 }; 4762 4763 static struct clk_branch gcc_qupv3_wrap0_s5_clk = { 4764 .halt_reg = 0x17734, 4765 .halt_check = BRANCH_HALT_VOTED, 4766 .clkr = { 4767 .enable_reg = 0x52008, 4768 .enable_mask = BIT(15), 4769 .hw.init = &(const struct clk_init_data) { 4770 .name = "gcc_qupv3_wrap0_s5_clk", 4771 .parent_hws = (const struct clk_hw*[]){ 4772 &gcc_qupv3_wrap0_s5_clk_src.clkr.hw, 4773 }, 4774 .num_parents = 1, 4775 .flags = CLK_SET_RATE_PARENT, 4776 .ops = &clk_branch2_ops, 4777 }, 4778 }, 4779 }; 4780 4781 static struct clk_branch gcc_qupv3_wrap0_s6_clk = { 4782 .halt_reg = 0x17864, 4783 .halt_check = BRANCH_HALT_VOTED, 4784 .clkr = { 4785 .enable_reg = 0x52008, 4786 .enable_mask = BIT(16), 4787 .hw.init = &(const struct clk_init_data) { 4788 .name = "gcc_qupv3_wrap0_s6_clk", 4789 .parent_hws = (const struct clk_hw*[]){ 4790 &gcc_qupv3_wrap0_s6_clk_src.clkr.hw, 4791 }, 4792 .num_parents = 1, 4793 .flags = CLK_SET_RATE_PARENT, 4794 .ops = &clk_branch2_ops, 4795 }, 4796 }, 4797 }; 4798 4799 static struct clk_branch gcc_qupv3_wrap0_s7_clk = { 4800 .halt_reg = 0x17994, 4801 .halt_check = BRANCH_HALT_VOTED, 4802 .clkr = { 4803 .enable_reg = 0x52008, 4804 .enable_mask = BIT(17), 4805 .hw.init = &(const struct clk_init_data) { 4806 .name = "gcc_qupv3_wrap0_s7_clk", 4807 .parent_hws = (const struct clk_hw*[]){ 4808 &gcc_qupv3_wrap0_s7_clk_src.clkr.hw, 4809 }, 4810 .num_parents = 1, 4811 .flags = CLK_SET_RATE_PARENT, 4812 .ops = &clk_branch2_ops, 4813 }, 4814 }, 4815 }; 4816 4817 static struct clk_branch gcc_qupv3_wrap1_core_2x_clk = { 4818 .halt_reg = 0x18014, 4819 .halt_check = BRANCH_HALT_VOTED, 4820 .clkr = { 4821 .enable_reg = 0x52008, 4822 .enable_mask = BIT(18), 4823 .hw.init = &(const struct clk_init_data) { 4824 .name = "gcc_qupv3_wrap1_core_2x_clk", 4825 .ops = &clk_branch2_ops, 4826 }, 4827 }, 4828 }; 4829 4830 static struct clk_branch gcc_qupv3_wrap1_core_clk = { 4831 .halt_reg = 0x1800c, 4832 .halt_check = BRANCH_HALT_VOTED, 4833 .clkr = { 4834 .enable_reg = 0x52008, 4835 .enable_mask = BIT(19), 4836 .hw.init = &(const struct clk_init_data) { 4837 .name = "gcc_qupv3_wrap1_core_clk", 4838 .ops = &clk_branch2_ops, 4839 }, 4840 }, 4841 }; 4842 4843 static struct clk_branch gcc_qupv3_wrap1_qspi0_clk = { 4844 .halt_reg = 0x18ac4, 4845 .halt_check = BRANCH_HALT_VOTED, 4846 .clkr = { 4847 .enable_reg = 0x52020, 4848 .enable_mask = BIT(2), 4849 .hw.init = &(const struct clk_init_data) { 4850 .name = "gcc_qupv3_wrap1_qspi0_clk", 4851 .parent_hws = (const struct clk_hw*[]){ 4852 &gcc_qupv3_wrap1_s4_clk_src.clkr.hw, 4853 }, 4854 .num_parents = 1, 4855 .flags = CLK_SET_RATE_PARENT, 4856 .ops = &clk_branch2_ops, 4857 }, 4858 }, 4859 }; 4860 4861 static struct clk_branch gcc_qupv3_wrap1_s0_clk = { 4862 .halt_reg = 0x18144, 4863 .halt_check = BRANCH_HALT_VOTED, 4864 .clkr = { 4865 .enable_reg = 0x52008, 4866 .enable_mask = BIT(22), 4867 .hw.init = &(const struct clk_init_data) { 4868 .name = "gcc_qupv3_wrap1_s0_clk", 4869 .parent_hws = (const struct clk_hw*[]){ 4870 &gcc_qupv3_wrap1_s0_clk_src.clkr.hw, 4871 }, 4872 .num_parents = 1, 4873 .flags = CLK_SET_RATE_PARENT, 4874 .ops = &clk_branch2_ops, 4875 }, 4876 }, 4877 }; 4878 4879 static struct clk_branch gcc_qupv3_wrap1_s1_clk = { 4880 .halt_reg = 0x18274, 4881 .halt_check = BRANCH_HALT_VOTED, 4882 .clkr = { 4883 .enable_reg = 0x52008, 4884 .enable_mask = BIT(23), 4885 .hw.init = &(const struct clk_init_data) { 4886 .name = "gcc_qupv3_wrap1_s1_clk", 4887 .parent_hws = (const struct clk_hw*[]){ 4888 &gcc_qupv3_wrap1_s1_clk_src.clkr.hw, 4889 }, 4890 .num_parents = 1, 4891 .flags = CLK_SET_RATE_PARENT, 4892 .ops = &clk_branch2_ops, 4893 }, 4894 }, 4895 }; 4896 4897 static struct clk_branch gcc_qupv3_wrap1_s2_clk = { 4898 .halt_reg = 0x183a4, 4899 .halt_check = BRANCH_HALT_VOTED, 4900 .clkr = { 4901 .enable_reg = 0x52008, 4902 .enable_mask = BIT(24), 4903 .hw.init = &(const struct clk_init_data) { 4904 .name = "gcc_qupv3_wrap1_s2_clk", 4905 .parent_hws = (const struct clk_hw*[]){ 4906 &gcc_qupv3_wrap1_s2_clk_src.clkr.hw, 4907 }, 4908 .num_parents = 1, 4909 .flags = CLK_SET_RATE_PARENT, 4910 .ops = &clk_branch2_ops, 4911 }, 4912 }, 4913 }; 4914 4915 static struct clk_branch gcc_qupv3_wrap1_s3_clk = { 4916 .halt_reg = 0x184d4, 4917 .halt_check = BRANCH_HALT_VOTED, 4918 .clkr = { 4919 .enable_reg = 0x52008, 4920 .enable_mask = BIT(25), 4921 .hw.init = &(const struct clk_init_data) { 4922 .name = "gcc_qupv3_wrap1_s3_clk", 4923 .parent_hws = (const struct clk_hw*[]){ 4924 &gcc_qupv3_wrap1_s3_clk_src.clkr.hw, 4925 }, 4926 .num_parents = 1, 4927 .flags = CLK_SET_RATE_PARENT, 4928 .ops = &clk_branch2_ops, 4929 }, 4930 }, 4931 }; 4932 4933 static struct clk_branch gcc_qupv3_wrap1_s4_clk = { 4934 .halt_reg = 0x18604, 4935 .halt_check = BRANCH_HALT_VOTED, 4936 .clkr = { 4937 .enable_reg = 0x52008, 4938 .enable_mask = BIT(26), 4939 .hw.init = &(const struct clk_init_data) { 4940 .name = "gcc_qupv3_wrap1_s4_clk", 4941 .parent_hws = (const struct clk_hw*[]){ 4942 &gcc_qupv3_wrap1_s4_div_clk_src.clkr.hw, 4943 }, 4944 .num_parents = 1, 4945 .flags = CLK_SET_RATE_PARENT, 4946 .ops = &clk_branch2_ops, 4947 }, 4948 }, 4949 }; 4950 4951 static struct clk_branch gcc_qupv3_wrap1_s5_clk = { 4952 .halt_reg = 0x18734, 4953 .halt_check = BRANCH_HALT_VOTED, 4954 .clkr = { 4955 .enable_reg = 0x52008, 4956 .enable_mask = BIT(27), 4957 .hw.init = &(const struct clk_init_data) { 4958 .name = "gcc_qupv3_wrap1_s5_clk", 4959 .parent_hws = (const struct clk_hw*[]){ 4960 &gcc_qupv3_wrap1_s5_clk_src.clkr.hw, 4961 }, 4962 .num_parents = 1, 4963 .flags = CLK_SET_RATE_PARENT, 4964 .ops = &clk_branch2_ops, 4965 }, 4966 }, 4967 }; 4968 4969 static struct clk_branch gcc_qupv3_wrap1_s6_clk = { 4970 .halt_reg = 0x18864, 4971 .halt_check = BRANCH_HALT_VOTED, 4972 .clkr = { 4973 .enable_reg = 0x52018, 4974 .enable_mask = BIT(27), 4975 .hw.init = &(const struct clk_init_data) { 4976 .name = "gcc_qupv3_wrap1_s6_clk", 4977 .parent_hws = (const struct clk_hw*[]){ 4978 &gcc_qupv3_wrap1_s6_clk_src.clkr.hw, 4979 }, 4980 .num_parents = 1, 4981 .flags = CLK_SET_RATE_PARENT, 4982 .ops = &clk_branch2_ops, 4983 }, 4984 }, 4985 }; 4986 4987 static struct clk_branch gcc_qupv3_wrap1_s7_clk = { 4988 .halt_reg = 0x18994, 4989 .halt_check = BRANCH_HALT_VOTED, 4990 .clkr = { 4991 .enable_reg = 0x52018, 4992 .enable_mask = BIT(28), 4993 .hw.init = &(const struct clk_init_data) { 4994 .name = "gcc_qupv3_wrap1_s7_clk", 4995 .parent_hws = (const struct clk_hw*[]){ 4996 &gcc_qupv3_wrap1_s7_clk_src.clkr.hw, 4997 }, 4998 .num_parents = 1, 4999 .flags = CLK_SET_RATE_PARENT, 5000 .ops = &clk_branch2_ops, 5001 }, 5002 }, 5003 }; 5004 5005 static struct clk_branch gcc_qupv3_wrap2_core_2x_clk = { 5006 .halt_reg = 0x1e014, 5007 .halt_check = BRANCH_HALT_VOTED, 5008 .clkr = { 5009 .enable_reg = 0x52010, 5010 .enable_mask = BIT(3), 5011 .hw.init = &(const struct clk_init_data) { 5012 .name = "gcc_qupv3_wrap2_core_2x_clk", 5013 .ops = &clk_branch2_ops, 5014 }, 5015 }, 5016 }; 5017 5018 static struct clk_branch gcc_qupv3_wrap2_core_clk = { 5019 .halt_reg = 0x1e00c, 5020 .halt_check = BRANCH_HALT_VOTED, 5021 .clkr = { 5022 .enable_reg = 0x52010, 5023 .enable_mask = BIT(0), 5024 .hw.init = &(const struct clk_init_data) { 5025 .name = "gcc_qupv3_wrap2_core_clk", 5026 .ops = &clk_branch2_ops, 5027 }, 5028 }, 5029 }; 5030 5031 static struct clk_branch gcc_qupv3_wrap2_qspi0_clk = { 5032 .halt_reg = 0x1eac4, 5033 .halt_check = BRANCH_HALT_VOTED, 5034 .clkr = { 5035 .enable_reg = 0x52020, 5036 .enable_mask = BIT(4), 5037 .hw.init = &(const struct clk_init_data) { 5038 .name = "gcc_qupv3_wrap2_qspi0_clk", 5039 .parent_hws = (const struct clk_hw*[]){ 5040 &gcc_qupv3_wrap2_s4_clk_src.clkr.hw, 5041 }, 5042 .num_parents = 1, 5043 .flags = CLK_SET_RATE_PARENT, 5044 .ops = &clk_branch2_ops, 5045 }, 5046 }, 5047 }; 5048 5049 static struct clk_branch gcc_qupv3_wrap2_s0_clk = { 5050 .halt_reg = 0x1e144, 5051 .halt_check = BRANCH_HALT_VOTED, 5052 .clkr = { 5053 .enable_reg = 0x52010, 5054 .enable_mask = BIT(4), 5055 .hw.init = &(const struct clk_init_data) { 5056 .name = "gcc_qupv3_wrap2_s0_clk", 5057 .parent_hws = (const struct clk_hw*[]){ 5058 &gcc_qupv3_wrap2_s0_clk_src.clkr.hw, 5059 }, 5060 .num_parents = 1, 5061 .flags = CLK_SET_RATE_PARENT, 5062 .ops = &clk_branch2_ops, 5063 }, 5064 }, 5065 }; 5066 5067 static struct clk_branch gcc_qupv3_wrap2_s1_clk = { 5068 .halt_reg = 0x1e274, 5069 .halt_check = BRANCH_HALT_VOTED, 5070 .clkr = { 5071 .enable_reg = 0x52010, 5072 .enable_mask = BIT(5), 5073 .hw.init = &(const struct clk_init_data) { 5074 .name = "gcc_qupv3_wrap2_s1_clk", 5075 .parent_hws = (const struct clk_hw*[]){ 5076 &gcc_qupv3_wrap2_s1_clk_src.clkr.hw, 5077 }, 5078 .num_parents = 1, 5079 .flags = CLK_SET_RATE_PARENT, 5080 .ops = &clk_branch2_ops, 5081 }, 5082 }, 5083 }; 5084 5085 static struct clk_branch gcc_qupv3_wrap2_s2_clk = { 5086 .halt_reg = 0x1e3a4, 5087 .halt_check = BRANCH_HALT_VOTED, 5088 .clkr = { 5089 .enable_reg = 0x52010, 5090 .enable_mask = BIT(6), 5091 .hw.init = &(const struct clk_init_data) { 5092 .name = "gcc_qupv3_wrap2_s2_clk", 5093 .parent_hws = (const struct clk_hw*[]){ 5094 &gcc_qupv3_wrap2_s2_clk_src.clkr.hw, 5095 }, 5096 .num_parents = 1, 5097 .flags = CLK_SET_RATE_PARENT, 5098 .ops = &clk_branch2_ops, 5099 }, 5100 }, 5101 }; 5102 5103 static struct clk_branch gcc_qupv3_wrap2_s3_clk = { 5104 .halt_reg = 0x1e4d4, 5105 .halt_check = BRANCH_HALT_VOTED, 5106 .clkr = { 5107 .enable_reg = 0x52010, 5108 .enable_mask = BIT(7), 5109 .hw.init = &(const struct clk_init_data) { 5110 .name = "gcc_qupv3_wrap2_s3_clk", 5111 .parent_hws = (const struct clk_hw*[]){ 5112 &gcc_qupv3_wrap2_s3_clk_src.clkr.hw, 5113 }, 5114 .num_parents = 1, 5115 .flags = CLK_SET_RATE_PARENT, 5116 .ops = &clk_branch2_ops, 5117 }, 5118 }, 5119 }; 5120 5121 static struct clk_branch gcc_qupv3_wrap2_s4_clk = { 5122 .halt_reg = 0x1e604, 5123 .halt_check = BRANCH_HALT_VOTED, 5124 .clkr = { 5125 .enable_reg = 0x52010, 5126 .enable_mask = BIT(8), 5127 .hw.init = &(const struct clk_init_data) { 5128 .name = "gcc_qupv3_wrap2_s4_clk", 5129 .parent_hws = (const struct clk_hw*[]){ 5130 &gcc_qupv3_wrap2_s4_div_clk_src.clkr.hw, 5131 }, 5132 .num_parents = 1, 5133 .flags = CLK_SET_RATE_PARENT, 5134 .ops = &clk_branch2_ops, 5135 }, 5136 }, 5137 }; 5138 5139 static struct clk_branch gcc_qupv3_wrap2_s5_clk = { 5140 .halt_reg = 0x1e734, 5141 .halt_check = BRANCH_HALT_VOTED, 5142 .clkr = { 5143 .enable_reg = 0x52010, 5144 .enable_mask = BIT(9), 5145 .hw.init = &(const struct clk_init_data) { 5146 .name = "gcc_qupv3_wrap2_s5_clk", 5147 .parent_hws = (const struct clk_hw*[]){ 5148 &gcc_qupv3_wrap2_s5_clk_src.clkr.hw, 5149 }, 5150 .num_parents = 1, 5151 .flags = CLK_SET_RATE_PARENT, 5152 .ops = &clk_branch2_ops, 5153 }, 5154 }, 5155 }; 5156 5157 static struct clk_branch gcc_qupv3_wrap2_s6_clk = { 5158 .halt_reg = 0x1e864, 5159 .halt_check = BRANCH_HALT_VOTED, 5160 .clkr = { 5161 .enable_reg = 0x52018, 5162 .enable_mask = BIT(29), 5163 .hw.init = &(const struct clk_init_data) { 5164 .name = "gcc_qupv3_wrap2_s6_clk", 5165 .parent_hws = (const struct clk_hw*[]){ 5166 &gcc_qupv3_wrap2_s6_clk_src.clkr.hw, 5167 }, 5168 .num_parents = 1, 5169 .flags = CLK_SET_RATE_PARENT, 5170 .ops = &clk_branch2_ops, 5171 }, 5172 }, 5173 }; 5174 5175 static struct clk_branch gcc_qupv3_wrap2_s7_clk = { 5176 .halt_reg = 0x1e994, 5177 .halt_check = BRANCH_HALT_VOTED, 5178 .clkr = { 5179 .enable_reg = 0x52018, 5180 .enable_mask = BIT(30), 5181 .hw.init = &(const struct clk_init_data) { 5182 .name = "gcc_qupv3_wrap2_s7_clk", 5183 .parent_hws = (const struct clk_hw*[]){ 5184 &gcc_qupv3_wrap2_s7_clk_src.clkr.hw, 5185 }, 5186 .num_parents = 1, 5187 .flags = CLK_SET_RATE_PARENT, 5188 .ops = &clk_branch2_ops, 5189 }, 5190 }, 5191 }; 5192 5193 static struct clk_branch gcc_qupv3_wrap_0_m_ahb_clk = { 5194 .halt_reg = 0x17004, 5195 .halt_check = BRANCH_HALT_VOTED, 5196 .hwcg_reg = 0x17004, 5197 .hwcg_bit = 1, 5198 .clkr = { 5199 .enable_reg = 0x52008, 5200 .enable_mask = BIT(6), 5201 .hw.init = &(const struct clk_init_data) { 5202 .name = "gcc_qupv3_wrap_0_m_ahb_clk", 5203 .ops = &clk_branch2_ops, 5204 }, 5205 }, 5206 }; 5207 5208 static struct clk_branch gcc_qupv3_wrap_0_s_ahb_clk = { 5209 .halt_reg = 0x17008, 5210 .halt_check = BRANCH_HALT_VOTED, 5211 .hwcg_reg = 0x17008, 5212 .hwcg_bit = 1, 5213 .clkr = { 5214 .enable_reg = 0x52008, 5215 .enable_mask = BIT(7), 5216 .hw.init = &(const struct clk_init_data) { 5217 .name = "gcc_qupv3_wrap_0_s_ahb_clk", 5218 .ops = &clk_branch2_ops, 5219 }, 5220 }, 5221 }; 5222 5223 static struct clk_branch gcc_qupv3_wrap_1_m_ahb_clk = { 5224 .halt_reg = 0x18004, 5225 .halt_check = BRANCH_HALT_VOTED, 5226 .hwcg_reg = 0x18004, 5227 .hwcg_bit = 1, 5228 .clkr = { 5229 .enable_reg = 0x52008, 5230 .enable_mask = BIT(20), 5231 .hw.init = &(const struct clk_init_data) { 5232 .name = "gcc_qupv3_wrap_1_m_ahb_clk", 5233 .ops = &clk_branch2_ops, 5234 }, 5235 }, 5236 }; 5237 5238 static struct clk_branch gcc_qupv3_wrap_1_s_ahb_clk = { 5239 .halt_reg = 0x18008, 5240 .halt_check = BRANCH_HALT_VOTED, 5241 .hwcg_reg = 0x18008, 5242 .hwcg_bit = 1, 5243 .clkr = { 5244 .enable_reg = 0x52008, 5245 .enable_mask = BIT(21), 5246 .hw.init = &(const struct clk_init_data) { 5247 .name = "gcc_qupv3_wrap_1_s_ahb_clk", 5248 .ops = &clk_branch2_ops, 5249 }, 5250 }, 5251 }; 5252 5253 static struct clk_branch gcc_qupv3_wrap_2_m_ahb_clk = { 5254 .halt_reg = 0x1e004, 5255 .halt_check = BRANCH_HALT_VOTED, 5256 .hwcg_reg = 0x1e004, 5257 .hwcg_bit = 1, 5258 .clkr = { 5259 .enable_reg = 0x52010, 5260 .enable_mask = BIT(2), 5261 .hw.init = &(const struct clk_init_data) { 5262 .name = "gcc_qupv3_wrap_2_m_ahb_clk", 5263 .ops = &clk_branch2_ops, 5264 }, 5265 }, 5266 }; 5267 5268 static struct clk_branch gcc_qupv3_wrap_2_s_ahb_clk = { 5269 .halt_reg = 0x1e008, 5270 .halt_check = BRANCH_HALT_VOTED, 5271 .hwcg_reg = 0x1e008, 5272 .hwcg_bit = 1, 5273 .clkr = { 5274 .enable_reg = 0x52010, 5275 .enable_mask = BIT(1), 5276 .hw.init = &(const struct clk_init_data) { 5277 .name = "gcc_qupv3_wrap_2_s_ahb_clk", 5278 .ops = &clk_branch2_ops, 5279 }, 5280 }, 5281 }; 5282 5283 static struct clk_branch gcc_sdcc2_ahb_clk = { 5284 .halt_reg = 0x14008, 5285 .halt_check = BRANCH_HALT, 5286 .clkr = { 5287 .enable_reg = 0x14008, 5288 .enable_mask = BIT(0), 5289 .hw.init = &(const struct clk_init_data) { 5290 .name = "gcc_sdcc2_ahb_clk", 5291 .ops = &clk_branch2_ops, 5292 }, 5293 }, 5294 }; 5295 5296 static struct clk_branch gcc_sdcc2_apps_clk = { 5297 .halt_reg = 0x14004, 5298 .halt_check = BRANCH_HALT, 5299 .clkr = { 5300 .enable_reg = 0x14004, 5301 .enable_mask = BIT(0), 5302 .hw.init = &(const struct clk_init_data) { 5303 .name = "gcc_sdcc2_apps_clk", 5304 .parent_hws = (const struct clk_hw*[]){ 5305 &gcc_sdcc2_apps_clk_src.clkr.hw, 5306 }, 5307 .num_parents = 1, 5308 .flags = CLK_SET_RATE_PARENT, 5309 .ops = &clk_branch2_ops, 5310 }, 5311 }, 5312 }; 5313 5314 static struct clk_branch gcc_sdcc4_ahb_clk = { 5315 .halt_reg = 0x16008, 5316 .halt_check = BRANCH_HALT, 5317 .clkr = { 5318 .enable_reg = 0x16008, 5319 .enable_mask = BIT(0), 5320 .hw.init = &(const struct clk_init_data) { 5321 .name = "gcc_sdcc4_ahb_clk", 5322 .ops = &clk_branch2_ops, 5323 }, 5324 }, 5325 }; 5326 5327 static struct clk_branch gcc_sdcc4_apps_clk = { 5328 .halt_reg = 0x16004, 5329 .halt_check = BRANCH_HALT, 5330 .clkr = { 5331 .enable_reg = 0x16004, 5332 .enable_mask = BIT(0), 5333 .hw.init = &(const struct clk_init_data) { 5334 .name = "gcc_sdcc4_apps_clk", 5335 .parent_hws = (const struct clk_hw*[]){ 5336 &gcc_sdcc4_apps_clk_src.clkr.hw, 5337 }, 5338 .num_parents = 1, 5339 .flags = CLK_SET_RATE_PARENT, 5340 .ops = &clk_branch2_ops, 5341 }, 5342 }, 5343 }; 5344 5345 static struct clk_branch gcc_sys_noc_usb_axi_clk = { 5346 .halt_reg = 0x5d000, 5347 .halt_check = BRANCH_HALT_VOTED, 5348 .hwcg_reg = 0x5d000, 5349 .hwcg_bit = 1, 5350 .clkr = { 5351 .enable_reg = 0x5d000, 5352 .enable_mask = BIT(0), 5353 .hw.init = &(const struct clk_init_data) { 5354 .name = "gcc_sys_noc_usb_axi_clk", 5355 .ops = &clk_branch2_ops, 5356 }, 5357 }, 5358 }; 5359 5360 static struct clk_branch gcc_ufs_1_card_clkref_clk = { 5361 .halt_reg = 0x8c000, 5362 .halt_check = BRANCH_HALT, 5363 .clkr = { 5364 .enable_reg = 0x8c000, 5365 .enable_mask = BIT(0), 5366 .hw.init = &(const struct clk_init_data) { 5367 .name = "gcc_ufs_1_card_clkref_clk", 5368 .parent_data = &gcc_parent_data_tcxo, 5369 .num_parents = 1, 5370 .ops = &clk_branch2_ops, 5371 }, 5372 }, 5373 }; 5374 5375 static struct clk_branch gcc_ufs_card_ahb_clk = { 5376 .halt_reg = 0x75018, 5377 .halt_check = BRANCH_HALT_VOTED, 5378 .hwcg_reg = 0x75018, 5379 .hwcg_bit = 1, 5380 .clkr = { 5381 .enable_reg = 0x75018, 5382 .enable_mask = BIT(0), 5383 .hw.init = &(const struct clk_init_data) { 5384 .name = "gcc_ufs_card_ahb_clk", 5385 .ops = &clk_branch2_ops, 5386 }, 5387 }, 5388 }; 5389 5390 static struct clk_branch gcc_ufs_card_axi_clk = { 5391 .halt_reg = 0x75010, 5392 .halt_check = BRANCH_HALT_VOTED, 5393 .hwcg_reg = 0x75010, 5394 .hwcg_bit = 1, 5395 .clkr = { 5396 .enable_reg = 0x75010, 5397 .enable_mask = BIT(0), 5398 .hw.init = &(const struct clk_init_data) { 5399 .name = "gcc_ufs_card_axi_clk", 5400 .parent_hws = (const struct clk_hw*[]){ 5401 &gcc_ufs_card_axi_clk_src.clkr.hw, 5402 }, 5403 .num_parents = 1, 5404 .flags = CLK_SET_RATE_PARENT, 5405 .ops = &clk_branch2_ops, 5406 }, 5407 }, 5408 }; 5409 5410 static struct clk_branch gcc_ufs_card_axi_hw_ctl_clk = { 5411 .halt_reg = 0x75010, 5412 .halt_check = BRANCH_HALT_VOTED, 5413 .hwcg_reg = 0x75010, 5414 .hwcg_bit = 1, 5415 .clkr = { 5416 .enable_reg = 0x75010, 5417 .enable_mask = BIT(1), 5418 .hw.init = &(const struct clk_init_data) { 5419 .name = "gcc_ufs_card_axi_hw_ctl_clk", 5420 .parent_hws = (const struct clk_hw*[]){ 5421 &gcc_ufs_card_axi_clk_src.clkr.hw, 5422 }, 5423 .num_parents = 1, 5424 .flags = CLK_SET_RATE_PARENT, 5425 .ops = &clk_branch2_ops, 5426 }, 5427 }, 5428 }; 5429 5430 static struct clk_branch gcc_ufs_card_clkref_clk = { 5431 .halt_reg = 0x8c054, 5432 .halt_check = BRANCH_HALT, 5433 .clkr = { 5434 .enable_reg = 0x8c054, 5435 .enable_mask = BIT(0), 5436 .hw.init = &(const struct clk_init_data) { 5437 .name = "gcc_ufs_card_clkref_clk", 5438 .parent_data = &gcc_parent_data_tcxo, 5439 .num_parents = 1, 5440 .ops = &clk_branch2_ops, 5441 }, 5442 }, 5443 }; 5444 5445 static struct clk_branch gcc_ufs_card_ice_core_clk = { 5446 .halt_reg = 0x75064, 5447 .halt_check = BRANCH_HALT_VOTED, 5448 .hwcg_reg = 0x75064, 5449 .hwcg_bit = 1, 5450 .clkr = { 5451 .enable_reg = 0x75064, 5452 .enable_mask = BIT(0), 5453 .hw.init = &(const struct clk_init_data) { 5454 .name = "gcc_ufs_card_ice_core_clk", 5455 .parent_hws = (const struct clk_hw*[]){ 5456 &gcc_ufs_card_ice_core_clk_src.clkr.hw, 5457 }, 5458 .num_parents = 1, 5459 .flags = CLK_SET_RATE_PARENT, 5460 .ops = &clk_branch2_ops, 5461 }, 5462 }, 5463 }; 5464 5465 static struct clk_branch gcc_ufs_card_ice_core_hw_ctl_clk = { 5466 .halt_reg = 0x75064, 5467 .halt_check = BRANCH_HALT_VOTED, 5468 .hwcg_reg = 0x75064, 5469 .hwcg_bit = 1, 5470 .clkr = { 5471 .enable_reg = 0x75064, 5472 .enable_mask = BIT(1), 5473 .hw.init = &(const struct clk_init_data) { 5474 .name = "gcc_ufs_card_ice_core_hw_ctl_clk", 5475 .parent_hws = (const struct clk_hw*[]){ 5476 &gcc_ufs_card_ice_core_clk_src.clkr.hw, 5477 }, 5478 .num_parents = 1, 5479 .flags = CLK_SET_RATE_PARENT, 5480 .ops = &clk_branch2_ops, 5481 }, 5482 }, 5483 }; 5484 5485 static struct clk_branch gcc_ufs_card_phy_aux_clk = { 5486 .halt_reg = 0x7509c, 5487 .halt_check = BRANCH_HALT_VOTED, 5488 .hwcg_reg = 0x7509c, 5489 .hwcg_bit = 1, 5490 .clkr = { 5491 .enable_reg = 0x7509c, 5492 .enable_mask = BIT(0), 5493 .hw.init = &(const struct clk_init_data) { 5494 .name = "gcc_ufs_card_phy_aux_clk", 5495 .parent_hws = (const struct clk_hw*[]){ 5496 &gcc_ufs_card_phy_aux_clk_src.clkr.hw, 5497 }, 5498 .num_parents = 1, 5499 .flags = CLK_SET_RATE_PARENT, 5500 .ops = &clk_branch2_ops, 5501 }, 5502 }, 5503 }; 5504 5505 static struct clk_branch gcc_ufs_card_phy_aux_hw_ctl_clk = { 5506 .halt_reg = 0x7509c, 5507 .halt_check = BRANCH_HALT_VOTED, 5508 .hwcg_reg = 0x7509c, 5509 .hwcg_bit = 1, 5510 .clkr = { 5511 .enable_reg = 0x7509c, 5512 .enable_mask = BIT(1), 5513 .hw.init = &(const struct clk_init_data) { 5514 .name = "gcc_ufs_card_phy_aux_hw_ctl_clk", 5515 .parent_hws = (const struct clk_hw*[]){ 5516 &gcc_ufs_card_phy_aux_clk_src.clkr.hw, 5517 }, 5518 .num_parents = 1, 5519 .flags = CLK_SET_RATE_PARENT, 5520 .ops = &clk_branch2_ops, 5521 }, 5522 }, 5523 }; 5524 5525 static struct clk_branch gcc_ufs_card_rx_symbol_0_clk = { 5526 .halt_reg = 0x75020, 5527 .halt_check = BRANCH_HALT_DELAY, 5528 .clkr = { 5529 .enable_reg = 0x75020, 5530 .enable_mask = BIT(0), 5531 .hw.init = &(const struct clk_init_data) { 5532 .name = "gcc_ufs_card_rx_symbol_0_clk", 5533 .parent_hws = (const struct clk_hw*[]){ 5534 &gcc_ufs_card_rx_symbol_0_clk_src.clkr.hw, 5535 }, 5536 .num_parents = 1, 5537 .flags = CLK_SET_RATE_PARENT, 5538 .ops = &clk_branch2_ops, 5539 }, 5540 }, 5541 }; 5542 5543 static struct clk_branch gcc_ufs_card_rx_symbol_1_clk = { 5544 .halt_reg = 0x750b8, 5545 .halt_check = BRANCH_HALT_DELAY, 5546 .clkr = { 5547 .enable_reg = 0x750b8, 5548 .enable_mask = BIT(0), 5549 .hw.init = &(const struct clk_init_data) { 5550 .name = "gcc_ufs_card_rx_symbol_1_clk", 5551 .parent_hws = (const struct clk_hw*[]){ 5552 &gcc_ufs_card_rx_symbol_1_clk_src.clkr.hw, 5553 }, 5554 .num_parents = 1, 5555 .flags = CLK_SET_RATE_PARENT, 5556 .ops = &clk_branch2_ops, 5557 }, 5558 }, 5559 }; 5560 5561 static struct clk_branch gcc_ufs_card_tx_symbol_0_clk = { 5562 .halt_reg = 0x7501c, 5563 .halt_check = BRANCH_HALT_DELAY, 5564 .clkr = { 5565 .enable_reg = 0x7501c, 5566 .enable_mask = BIT(0), 5567 .hw.init = &(const struct clk_init_data) { 5568 .name = "gcc_ufs_card_tx_symbol_0_clk", 5569 .parent_hws = (const struct clk_hw*[]){ 5570 &gcc_ufs_card_tx_symbol_0_clk_src.clkr.hw, 5571 }, 5572 .num_parents = 1, 5573 .flags = CLK_SET_RATE_PARENT, 5574 .ops = &clk_branch2_ops, 5575 }, 5576 }, 5577 }; 5578 5579 static struct clk_branch gcc_ufs_card_unipro_core_clk = { 5580 .halt_reg = 0x7505c, 5581 .halt_check = BRANCH_HALT_VOTED, 5582 .hwcg_reg = 0x7505c, 5583 .hwcg_bit = 1, 5584 .clkr = { 5585 .enable_reg = 0x7505c, 5586 .enable_mask = BIT(0), 5587 .hw.init = &(const struct clk_init_data) { 5588 .name = "gcc_ufs_card_unipro_core_clk", 5589 .parent_hws = (const struct clk_hw*[]){ 5590 &gcc_ufs_card_unipro_core_clk_src.clkr.hw, 5591 }, 5592 .num_parents = 1, 5593 .flags = CLK_SET_RATE_PARENT, 5594 .ops = &clk_branch2_ops, 5595 }, 5596 }, 5597 }; 5598 5599 static struct clk_branch gcc_ufs_card_unipro_core_hw_ctl_clk = { 5600 .halt_reg = 0x7505c, 5601 .halt_check = BRANCH_HALT_VOTED, 5602 .hwcg_reg = 0x7505c, 5603 .hwcg_bit = 1, 5604 .clkr = { 5605 .enable_reg = 0x7505c, 5606 .enable_mask = BIT(1), 5607 .hw.init = &(const struct clk_init_data) { 5608 .name = "gcc_ufs_card_unipro_core_hw_ctl_clk", 5609 .parent_hws = (const struct clk_hw*[]){ 5610 &gcc_ufs_card_unipro_core_clk_src.clkr.hw, 5611 }, 5612 .num_parents = 1, 5613 .flags = CLK_SET_RATE_PARENT, 5614 .ops = &clk_branch2_ops, 5615 }, 5616 }, 5617 }; 5618 5619 static struct clk_branch gcc_ufs_phy_ahb_clk = { 5620 .halt_reg = 0x77018, 5621 .halt_check = BRANCH_HALT_VOTED, 5622 .hwcg_reg = 0x77018, 5623 .hwcg_bit = 1, 5624 .clkr = { 5625 .enable_reg = 0x77018, 5626 .enable_mask = BIT(0), 5627 .hw.init = &(const struct clk_init_data) { 5628 .name = "gcc_ufs_phy_ahb_clk", 5629 .ops = &clk_branch2_ops, 5630 }, 5631 }, 5632 }; 5633 5634 static struct clk_branch gcc_ufs_phy_axi_clk = { 5635 .halt_reg = 0x77010, 5636 .halt_check = BRANCH_HALT_VOTED, 5637 .hwcg_reg = 0x77010, 5638 .hwcg_bit = 1, 5639 .clkr = { 5640 .enable_reg = 0x77010, 5641 .enable_mask = BIT(0), 5642 .hw.init = &(const struct clk_init_data) { 5643 .name = "gcc_ufs_phy_axi_clk", 5644 .parent_hws = (const struct clk_hw*[]){ 5645 &gcc_ufs_phy_axi_clk_src.clkr.hw, 5646 }, 5647 .num_parents = 1, 5648 .flags = CLK_SET_RATE_PARENT, 5649 .ops = &clk_branch2_ops, 5650 }, 5651 }, 5652 }; 5653 5654 static struct clk_branch gcc_ufs_phy_axi_hw_ctl_clk = { 5655 .halt_reg = 0x77010, 5656 .halt_check = BRANCH_HALT_VOTED, 5657 .hwcg_reg = 0x77010, 5658 .hwcg_bit = 1, 5659 .clkr = { 5660 .enable_reg = 0x77010, 5661 .enable_mask = BIT(1), 5662 .hw.init = &(const struct clk_init_data) { 5663 .name = "gcc_ufs_phy_axi_hw_ctl_clk", 5664 .parent_hws = (const struct clk_hw*[]){ 5665 &gcc_ufs_phy_axi_clk_src.clkr.hw, 5666 }, 5667 .num_parents = 1, 5668 .flags = CLK_SET_RATE_PARENT, 5669 .ops = &clk_branch2_ops, 5670 }, 5671 }, 5672 }; 5673 5674 static struct clk_branch gcc_ufs_phy_ice_core_clk = { 5675 .halt_reg = 0x77064, 5676 .halt_check = BRANCH_HALT_VOTED, 5677 .hwcg_reg = 0x77064, 5678 .hwcg_bit = 1, 5679 .clkr = { 5680 .enable_reg = 0x77064, 5681 .enable_mask = BIT(0), 5682 .hw.init = &(const struct clk_init_data) { 5683 .name = "gcc_ufs_phy_ice_core_clk", 5684 .parent_hws = (const struct clk_hw*[]){ 5685 &gcc_ufs_phy_ice_core_clk_src.clkr.hw, 5686 }, 5687 .num_parents = 1, 5688 .flags = CLK_SET_RATE_PARENT, 5689 .ops = &clk_branch2_ops, 5690 }, 5691 }, 5692 }; 5693 5694 static struct clk_branch gcc_ufs_phy_ice_core_hw_ctl_clk = { 5695 .halt_reg = 0x77064, 5696 .halt_check = BRANCH_HALT_VOTED, 5697 .hwcg_reg = 0x77064, 5698 .hwcg_bit = 1, 5699 .clkr = { 5700 .enable_reg = 0x77064, 5701 .enable_mask = BIT(1), 5702 .hw.init = &(const struct clk_init_data) { 5703 .name = "gcc_ufs_phy_ice_core_hw_ctl_clk", 5704 .parent_hws = (const struct clk_hw*[]){ 5705 &gcc_ufs_phy_ice_core_clk_src.clkr.hw, 5706 }, 5707 .num_parents = 1, 5708 .flags = CLK_SET_RATE_PARENT, 5709 .ops = &clk_branch2_ops, 5710 }, 5711 }, 5712 }; 5713 5714 static struct clk_branch gcc_ufs_phy_phy_aux_clk = { 5715 .halt_reg = 0x7709c, 5716 .halt_check = BRANCH_HALT_VOTED, 5717 .hwcg_reg = 0x7709c, 5718 .hwcg_bit = 1, 5719 .clkr = { 5720 .enable_reg = 0x7709c, 5721 .enable_mask = BIT(0), 5722 .hw.init = &(const struct clk_init_data) { 5723 .name = "gcc_ufs_phy_phy_aux_clk", 5724 .parent_hws = (const struct clk_hw*[]){ 5725 &gcc_ufs_phy_phy_aux_clk_src.clkr.hw, 5726 }, 5727 .num_parents = 1, 5728 .flags = CLK_SET_RATE_PARENT, 5729 .ops = &clk_branch2_ops, 5730 }, 5731 }, 5732 }; 5733 5734 static struct clk_branch gcc_ufs_phy_phy_aux_hw_ctl_clk = { 5735 .halt_reg = 0x7709c, 5736 .halt_check = BRANCH_HALT_VOTED, 5737 .hwcg_reg = 0x7709c, 5738 .hwcg_bit = 1, 5739 .clkr = { 5740 .enable_reg = 0x7709c, 5741 .enable_mask = BIT(1), 5742 .hw.init = &(const struct clk_init_data) { 5743 .name = "gcc_ufs_phy_phy_aux_hw_ctl_clk", 5744 .parent_hws = (const struct clk_hw*[]){ 5745 &gcc_ufs_phy_phy_aux_clk_src.clkr.hw, 5746 }, 5747 .num_parents = 1, 5748 .flags = CLK_SET_RATE_PARENT, 5749 .ops = &clk_branch2_ops, 5750 }, 5751 }, 5752 }; 5753 5754 static struct clk_branch gcc_ufs_phy_rx_symbol_0_clk = { 5755 .halt_reg = 0x77020, 5756 .halt_check = BRANCH_HALT_DELAY, 5757 .clkr = { 5758 .enable_reg = 0x77020, 5759 .enable_mask = BIT(0), 5760 .hw.init = &(const struct clk_init_data) { 5761 .name = "gcc_ufs_phy_rx_symbol_0_clk", 5762 .parent_hws = (const struct clk_hw*[]){ 5763 &gcc_ufs_phy_rx_symbol_0_clk_src.clkr.hw, 5764 }, 5765 .num_parents = 1, 5766 .flags = CLK_SET_RATE_PARENT, 5767 .ops = &clk_branch2_ops, 5768 }, 5769 }, 5770 }; 5771 5772 static struct clk_branch gcc_ufs_phy_rx_symbol_1_clk = { 5773 .halt_reg = 0x770b8, 5774 .halt_check = BRANCH_HALT_DELAY, 5775 .clkr = { 5776 .enable_reg = 0x770b8, 5777 .enable_mask = BIT(0), 5778 .hw.init = &(const struct clk_init_data) { 5779 .name = "gcc_ufs_phy_rx_symbol_1_clk", 5780 .parent_hws = (const struct clk_hw*[]){ 5781 &gcc_ufs_phy_rx_symbol_1_clk_src.clkr.hw, 5782 }, 5783 .num_parents = 1, 5784 .flags = CLK_SET_RATE_PARENT, 5785 .ops = &clk_branch2_ops, 5786 }, 5787 }, 5788 }; 5789 5790 static struct clk_branch gcc_ufs_phy_tx_symbol_0_clk = { 5791 .halt_reg = 0x7701c, 5792 .halt_check = BRANCH_HALT_DELAY, 5793 .clkr = { 5794 .enable_reg = 0x7701c, 5795 .enable_mask = BIT(0), 5796 .hw.init = &(const struct clk_init_data) { 5797 .name = "gcc_ufs_phy_tx_symbol_0_clk", 5798 .parent_hws = (const struct clk_hw*[]){ 5799 &gcc_ufs_phy_tx_symbol_0_clk_src.clkr.hw, 5800 }, 5801 .num_parents = 1, 5802 .flags = CLK_SET_RATE_PARENT, 5803 .ops = &clk_branch2_ops, 5804 }, 5805 }, 5806 }; 5807 5808 static struct clk_branch gcc_ufs_phy_unipro_core_clk = { 5809 .halt_reg = 0x7705c, 5810 .halt_check = BRANCH_HALT_VOTED, 5811 .hwcg_reg = 0x7705c, 5812 .hwcg_bit = 1, 5813 .clkr = { 5814 .enable_reg = 0x7705c, 5815 .enable_mask = BIT(0), 5816 .hw.init = &(const struct clk_init_data) { 5817 .name = "gcc_ufs_phy_unipro_core_clk", 5818 .parent_hws = (const struct clk_hw*[]){ 5819 &gcc_ufs_phy_unipro_core_clk_src.clkr.hw, 5820 }, 5821 .num_parents = 1, 5822 .flags = CLK_SET_RATE_PARENT, 5823 .ops = &clk_branch2_ops, 5824 }, 5825 }, 5826 }; 5827 5828 static struct clk_branch gcc_ufs_phy_unipro_core_hw_ctl_clk = { 5829 .halt_reg = 0x7705c, 5830 .halt_check = BRANCH_HALT_VOTED, 5831 .hwcg_reg = 0x7705c, 5832 .hwcg_bit = 1, 5833 .clkr = { 5834 .enable_reg = 0x7705c, 5835 .enable_mask = BIT(1), 5836 .hw.init = &(const struct clk_init_data) { 5837 .name = "gcc_ufs_phy_unipro_core_hw_ctl_clk", 5838 .parent_hws = (const struct clk_hw*[]){ 5839 &gcc_ufs_phy_unipro_core_clk_src.clkr.hw, 5840 }, 5841 .num_parents = 1, 5842 .flags = CLK_SET_RATE_PARENT, 5843 .ops = &clk_branch2_ops, 5844 }, 5845 }, 5846 }; 5847 5848 static struct clk_branch gcc_ufs_ref_clkref_clk = { 5849 .halt_reg = 0x8c058, 5850 .halt_check = BRANCH_HALT, 5851 .clkr = { 5852 .enable_reg = 0x8c058, 5853 .enable_mask = BIT(0), 5854 .hw.init = &(const struct clk_init_data) { 5855 .name = "gcc_ufs_ref_clkref_clk", 5856 .parent_data = &gcc_parent_data_tcxo, 5857 .num_parents = 1, 5858 .ops = &clk_branch2_ops, 5859 }, 5860 }, 5861 }; 5862 5863 static struct clk_branch gcc_usb2_hs0_clkref_clk = { 5864 .halt_reg = 0x8c044, 5865 .halt_check = BRANCH_HALT, 5866 .clkr = { 5867 .enable_reg = 0x8c044, 5868 .enable_mask = BIT(0), 5869 .hw.init = &(const struct clk_init_data) { 5870 .name = "gcc_usb2_hs0_clkref_clk", 5871 .ops = &clk_branch2_ops, 5872 }, 5873 }, 5874 }; 5875 5876 static struct clk_branch gcc_usb2_hs1_clkref_clk = { 5877 .halt_reg = 0x8c048, 5878 .halt_check = BRANCH_HALT, 5879 .clkr = { 5880 .enable_reg = 0x8c048, 5881 .enable_mask = BIT(0), 5882 .hw.init = &(const struct clk_init_data) { 5883 .name = "gcc_usb2_hs1_clkref_clk", 5884 .ops = &clk_branch2_ops, 5885 }, 5886 }, 5887 }; 5888 5889 static struct clk_branch gcc_usb2_hs2_clkref_clk = { 5890 .halt_reg = 0x8c04c, 5891 .halt_check = BRANCH_HALT, 5892 .clkr = { 5893 .enable_reg = 0x8c04c, 5894 .enable_mask = BIT(0), 5895 .hw.init = &(const struct clk_init_data) { 5896 .name = "gcc_usb2_hs2_clkref_clk", 5897 .ops = &clk_branch2_ops, 5898 }, 5899 }, 5900 }; 5901 5902 static struct clk_branch gcc_usb2_hs3_clkref_clk = { 5903 .halt_reg = 0x8c050, 5904 .halt_check = BRANCH_HALT, 5905 .clkr = { 5906 .enable_reg = 0x8c050, 5907 .enable_mask = BIT(0), 5908 .hw.init = &(const struct clk_init_data) { 5909 .name = "gcc_usb2_hs3_clkref_clk", 5910 .ops = &clk_branch2_ops, 5911 }, 5912 }, 5913 }; 5914 5915 static struct clk_branch gcc_usb30_mp_master_clk = { 5916 .halt_reg = 0xab010, 5917 .halt_check = BRANCH_HALT, 5918 .clkr = { 5919 .enable_reg = 0xab010, 5920 .enable_mask = BIT(0), 5921 .hw.init = &(const struct clk_init_data) { 5922 .name = "gcc_usb30_mp_master_clk", 5923 .parent_hws = (const struct clk_hw*[]){ 5924 &gcc_usb30_mp_master_clk_src.clkr.hw, 5925 }, 5926 .num_parents = 1, 5927 .flags = CLK_SET_RATE_PARENT, 5928 .ops = &clk_branch2_ops, 5929 }, 5930 }, 5931 }; 5932 5933 static struct clk_branch gcc_usb30_mp_mock_utmi_clk = { 5934 .halt_reg = 0xab01c, 5935 .halt_check = BRANCH_HALT, 5936 .clkr = { 5937 .enable_reg = 0xab01c, 5938 .enable_mask = BIT(0), 5939 .hw.init = &(const struct clk_init_data) { 5940 .name = "gcc_usb30_mp_mock_utmi_clk", 5941 .parent_hws = (const struct clk_hw*[]){ 5942 &gcc_usb30_mp_mock_utmi_postdiv_clk_src.clkr.hw, 5943 }, 5944 .num_parents = 1, 5945 .flags = CLK_SET_RATE_PARENT, 5946 .ops = &clk_branch2_ops, 5947 }, 5948 }, 5949 }; 5950 5951 static struct clk_branch gcc_usb30_mp_sleep_clk = { 5952 .halt_reg = 0xab018, 5953 .halt_check = BRANCH_HALT, 5954 .clkr = { 5955 .enable_reg = 0xab018, 5956 .enable_mask = BIT(0), 5957 .hw.init = &(const struct clk_init_data) { 5958 .name = "gcc_usb30_mp_sleep_clk", 5959 .ops = &clk_branch2_ops, 5960 }, 5961 }, 5962 }; 5963 5964 static struct clk_branch gcc_usb30_prim_master_clk = { 5965 .halt_reg = 0xf010, 5966 .halt_check = BRANCH_HALT, 5967 .clkr = { 5968 .enable_reg = 0xf010, 5969 .enable_mask = BIT(0), 5970 .hw.init = &(const struct clk_init_data) { 5971 .name = "gcc_usb30_prim_master_clk", 5972 .parent_hws = (const struct clk_hw*[]){ 5973 &gcc_usb30_prim_master_clk_src.clkr.hw, 5974 }, 5975 .num_parents = 1, 5976 .flags = CLK_SET_RATE_PARENT, 5977 .ops = &clk_branch2_ops, 5978 }, 5979 }, 5980 }; 5981 5982 static struct clk_branch gcc_usb30_prim_mock_utmi_clk = { 5983 .halt_reg = 0xf01c, 5984 .halt_check = BRANCH_HALT, 5985 .clkr = { 5986 .enable_reg = 0xf01c, 5987 .enable_mask = BIT(0), 5988 .hw.init = &(const struct clk_init_data) { 5989 .name = "gcc_usb30_prim_mock_utmi_clk", 5990 .parent_hws = (const struct clk_hw*[]){ 5991 &gcc_usb30_prim_mock_utmi_postdiv_clk_src.clkr.hw, 5992 }, 5993 .num_parents = 1, 5994 .flags = CLK_SET_RATE_PARENT, 5995 .ops = &clk_branch2_ops, 5996 }, 5997 }, 5998 }; 5999 6000 static struct clk_branch gcc_usb30_prim_sleep_clk = { 6001 .halt_reg = 0xf018, 6002 .halt_check = BRANCH_HALT, 6003 .clkr = { 6004 .enable_reg = 0xf018, 6005 .enable_mask = BIT(0), 6006 .hw.init = &(const struct clk_init_data) { 6007 .name = "gcc_usb30_prim_sleep_clk", 6008 .ops = &clk_branch2_ops, 6009 }, 6010 }, 6011 }; 6012 6013 static struct clk_branch gcc_usb30_sec_master_clk = { 6014 .halt_reg = 0x10010, 6015 .halt_check = BRANCH_HALT, 6016 .clkr = { 6017 .enable_reg = 0x10010, 6018 .enable_mask = BIT(0), 6019 .hw.init = &(const struct clk_init_data) { 6020 .name = "gcc_usb30_sec_master_clk", 6021 .parent_hws = (const struct clk_hw*[]){ 6022 &gcc_usb30_sec_master_clk_src.clkr.hw, 6023 }, 6024 .num_parents = 1, 6025 .flags = CLK_SET_RATE_PARENT, 6026 .ops = &clk_branch2_ops, 6027 }, 6028 }, 6029 }; 6030 6031 static struct clk_branch gcc_usb30_sec_mock_utmi_clk = { 6032 .halt_reg = 0x1001c, 6033 .halt_check = BRANCH_HALT, 6034 .clkr = { 6035 .enable_reg = 0x1001c, 6036 .enable_mask = BIT(0), 6037 .hw.init = &(const struct clk_init_data) { 6038 .name = "gcc_usb30_sec_mock_utmi_clk", 6039 .parent_hws = (const struct clk_hw*[]){ 6040 &gcc_usb30_sec_mock_utmi_postdiv_clk_src.clkr.hw, 6041 }, 6042 .num_parents = 1, 6043 .flags = CLK_SET_RATE_PARENT, 6044 .ops = &clk_branch2_ops, 6045 }, 6046 }, 6047 }; 6048 6049 static struct clk_branch gcc_usb30_sec_sleep_clk = { 6050 .halt_reg = 0x10018, 6051 .halt_check = BRANCH_HALT, 6052 .clkr = { 6053 .enable_reg = 0x10018, 6054 .enable_mask = BIT(0), 6055 .hw.init = &(const struct clk_init_data) { 6056 .name = "gcc_usb30_sec_sleep_clk", 6057 .ops = &clk_branch2_ops, 6058 }, 6059 }, 6060 }; 6061 6062 static struct clk_branch gcc_usb3_mp0_clkref_clk = { 6063 .halt_reg = 0x8c03c, 6064 .halt_check = BRANCH_HALT, 6065 .clkr = { 6066 .enable_reg = 0x8c03c, 6067 .enable_mask = BIT(0), 6068 .hw.init = &(const struct clk_init_data) { 6069 .name = "gcc_usb3_mp0_clkref_clk", 6070 .ops = &clk_branch2_ops, 6071 }, 6072 }, 6073 }; 6074 6075 static struct clk_branch gcc_usb3_mp1_clkref_clk = { 6076 .halt_reg = 0x8c040, 6077 .halt_check = BRANCH_HALT, 6078 .clkr = { 6079 .enable_reg = 0x8c040, 6080 .enable_mask = BIT(0), 6081 .hw.init = &(const struct clk_init_data) { 6082 .name = "gcc_usb3_mp1_clkref_clk", 6083 .ops = &clk_branch2_ops, 6084 }, 6085 }, 6086 }; 6087 6088 static struct clk_branch gcc_usb3_mp_phy_aux_clk = { 6089 .halt_reg = 0xab054, 6090 .halt_check = BRANCH_HALT, 6091 .clkr = { 6092 .enable_reg = 0xab054, 6093 .enable_mask = BIT(0), 6094 .hw.init = &(const struct clk_init_data) { 6095 .name = "gcc_usb3_mp_phy_aux_clk", 6096 .parent_hws = (const struct clk_hw*[]){ 6097 &gcc_usb3_mp_phy_aux_clk_src.clkr.hw, 6098 }, 6099 .num_parents = 1, 6100 .flags = CLK_SET_RATE_PARENT, 6101 .ops = &clk_branch2_ops, 6102 }, 6103 }, 6104 }; 6105 6106 static struct clk_branch gcc_usb3_mp_phy_com_aux_clk = { 6107 .halt_reg = 0xab058, 6108 .halt_check = BRANCH_HALT, 6109 .clkr = { 6110 .enable_reg = 0xab058, 6111 .enable_mask = BIT(0), 6112 .hw.init = &(const struct clk_init_data) { 6113 .name = "gcc_usb3_mp_phy_com_aux_clk", 6114 .parent_hws = (const struct clk_hw*[]){ 6115 &gcc_usb3_mp_phy_aux_clk_src.clkr.hw, 6116 }, 6117 .num_parents = 1, 6118 .flags = CLK_SET_RATE_PARENT, 6119 .ops = &clk_branch2_ops, 6120 }, 6121 }, 6122 }; 6123 6124 static struct clk_branch gcc_usb3_mp_phy_pipe_0_clk = { 6125 .halt_reg = 0xab05c, 6126 .halt_check = BRANCH_HALT_DELAY, 6127 .clkr = { 6128 .enable_reg = 0xab05c, 6129 .enable_mask = BIT(0), 6130 .hw.init = &(const struct clk_init_data) { 6131 .name = "gcc_usb3_mp_phy_pipe_0_clk", 6132 .parent_hws = (const struct clk_hw*[]){ 6133 &gcc_usb3_mp_phy_pipe_0_clk_src.clkr.hw, 6134 }, 6135 .num_parents = 1, 6136 .flags = CLK_SET_RATE_PARENT, 6137 .ops = &clk_branch2_ops, 6138 }, 6139 }, 6140 }; 6141 6142 static struct clk_branch gcc_usb3_mp_phy_pipe_1_clk = { 6143 .halt_reg = 0xab064, 6144 .halt_check = BRANCH_HALT_DELAY, 6145 .clkr = { 6146 .enable_reg = 0xab064, 6147 .enable_mask = BIT(0), 6148 .hw.init = &(const struct clk_init_data) { 6149 .name = "gcc_usb3_mp_phy_pipe_1_clk", 6150 .parent_hws = (const struct clk_hw*[]){ 6151 &gcc_usb3_mp_phy_pipe_1_clk_src.clkr.hw, 6152 }, 6153 .num_parents = 1, 6154 .flags = CLK_SET_RATE_PARENT, 6155 .ops = &clk_branch2_ops, 6156 }, 6157 }, 6158 }; 6159 6160 static struct clk_branch gcc_usb3_prim_phy_aux_clk = { 6161 .halt_reg = 0xf054, 6162 .halt_check = BRANCH_HALT, 6163 .clkr = { 6164 .enable_reg = 0xf054, 6165 .enable_mask = BIT(0), 6166 .hw.init = &(const struct clk_init_data) { 6167 .name = "gcc_usb3_prim_phy_aux_clk", 6168 .parent_hws = (const struct clk_hw*[]){ 6169 &gcc_usb3_prim_phy_aux_clk_src.clkr.hw, 6170 }, 6171 .num_parents = 1, 6172 .flags = CLK_SET_RATE_PARENT, 6173 .ops = &clk_branch2_ops, 6174 }, 6175 }, 6176 }; 6177 6178 static struct clk_branch gcc_usb3_prim_phy_com_aux_clk = { 6179 .halt_reg = 0xf058, 6180 .halt_check = BRANCH_HALT, 6181 .clkr = { 6182 .enable_reg = 0xf058, 6183 .enable_mask = BIT(0), 6184 .hw.init = &(const struct clk_init_data) { 6185 .name = "gcc_usb3_prim_phy_com_aux_clk", 6186 .parent_hws = (const struct clk_hw*[]){ 6187 &gcc_usb3_prim_phy_aux_clk_src.clkr.hw, 6188 }, 6189 .num_parents = 1, 6190 .flags = CLK_SET_RATE_PARENT, 6191 .ops = &clk_branch2_ops, 6192 }, 6193 }, 6194 }; 6195 6196 static struct clk_branch gcc_usb3_prim_phy_pipe_clk = { 6197 .halt_reg = 0xf05c, 6198 .halt_check = BRANCH_HALT_DELAY, 6199 .hwcg_reg = 0xf05c, 6200 .hwcg_bit = 1, 6201 .clkr = { 6202 .enable_reg = 0xf05c, 6203 .enable_mask = BIT(0), 6204 .hw.init = &(const struct clk_init_data) { 6205 .name = "gcc_usb3_prim_phy_pipe_clk", 6206 .parent_hws = (const struct clk_hw*[]){ 6207 &gcc_usb34_prim_phy_pipe_clk_src.clkr.hw, 6208 }, 6209 .num_parents = 1, 6210 .flags = CLK_SET_RATE_PARENT, 6211 .ops = &clk_branch2_ops, 6212 }, 6213 }, 6214 }; 6215 6216 static struct clk_branch gcc_usb3_sec_phy_aux_clk = { 6217 .halt_reg = 0x10054, 6218 .halt_check = BRANCH_HALT, 6219 .clkr = { 6220 .enable_reg = 0x10054, 6221 .enable_mask = BIT(0), 6222 .hw.init = &(const struct clk_init_data) { 6223 .name = "gcc_usb3_sec_phy_aux_clk", 6224 .parent_hws = (const struct clk_hw*[]){ 6225 &gcc_usb3_sec_phy_aux_clk_src.clkr.hw, 6226 }, 6227 .num_parents = 1, 6228 .flags = CLK_SET_RATE_PARENT, 6229 .ops = &clk_branch2_ops, 6230 }, 6231 }, 6232 }; 6233 6234 static struct clk_branch gcc_usb3_sec_phy_com_aux_clk = { 6235 .halt_reg = 0x10058, 6236 .halt_check = BRANCH_HALT, 6237 .clkr = { 6238 .enable_reg = 0x10058, 6239 .enable_mask = BIT(0), 6240 .hw.init = &(const struct clk_init_data) { 6241 .name = "gcc_usb3_sec_phy_com_aux_clk", 6242 .parent_hws = (const struct clk_hw*[]){ 6243 &gcc_usb3_sec_phy_aux_clk_src.clkr.hw, 6244 }, 6245 .num_parents = 1, 6246 .flags = CLK_SET_RATE_PARENT, 6247 .ops = &clk_branch2_ops, 6248 }, 6249 }, 6250 }; 6251 6252 static struct clk_branch gcc_usb3_sec_phy_pipe_clk = { 6253 .halt_reg = 0x1005c, 6254 .halt_check = BRANCH_HALT_DELAY, 6255 .hwcg_reg = 0x1005c, 6256 .hwcg_bit = 1, 6257 .clkr = { 6258 .enable_reg = 0x1005c, 6259 .enable_mask = BIT(0), 6260 .hw.init = &(const struct clk_init_data) { 6261 .name = "gcc_usb3_sec_phy_pipe_clk", 6262 .parent_hws = (const struct clk_hw*[]){ 6263 &gcc_usb34_sec_phy_pipe_clk_src.clkr.hw, 6264 }, 6265 .num_parents = 1, 6266 .flags = CLK_SET_RATE_PARENT, 6267 .ops = &clk_branch2_ops, 6268 }, 6269 }, 6270 }; 6271 6272 static struct clk_branch gcc_usb4_1_cfg_ahb_clk = { 6273 .halt_reg = 0xb808c, 6274 .halt_check = BRANCH_HALT_VOTED, 6275 .hwcg_reg = 0xb808c, 6276 .hwcg_bit = 1, 6277 .clkr = { 6278 .enable_reg = 0xb808c, 6279 .enable_mask = BIT(0), 6280 .hw.init = &(const struct clk_init_data) { 6281 .name = "gcc_usb4_1_cfg_ahb_clk", 6282 .ops = &clk_branch2_ops, 6283 }, 6284 }, 6285 }; 6286 6287 static struct clk_branch gcc_usb4_1_dp_clk = { 6288 .halt_reg = 0xb8048, 6289 .halt_check = BRANCH_HALT, 6290 .clkr = { 6291 .enable_reg = 0xb8048, 6292 .enable_mask = BIT(0), 6293 .hw.init = &(const struct clk_init_data) { 6294 .name = "gcc_usb4_1_dp_clk", 6295 .parent_hws = (const struct clk_hw*[]){ 6296 &gcc_usb4_1_phy_dp_clk_src.clkr.hw, 6297 }, 6298 .num_parents = 1, 6299 .flags = CLK_SET_RATE_PARENT, 6300 .ops = &clk_branch2_ops, 6301 }, 6302 }, 6303 }; 6304 6305 static struct clk_branch gcc_usb4_1_master_clk = { 6306 .halt_reg = 0xb8010, 6307 .halt_check = BRANCH_HALT, 6308 .clkr = { 6309 .enable_reg = 0xb8010, 6310 .enable_mask = BIT(0), 6311 .hw.init = &(const struct clk_init_data) { 6312 .name = "gcc_usb4_1_master_clk", 6313 .parent_hws = (const struct clk_hw*[]){ 6314 &gcc_usb4_1_master_clk_src.clkr.hw, 6315 }, 6316 .num_parents = 1, 6317 .flags = CLK_SET_RATE_PARENT, 6318 .ops = &clk_branch2_ops, 6319 }, 6320 }, 6321 }; 6322 6323 static struct clk_branch gcc_usb4_1_phy_p2rr2p_pipe_clk = { 6324 .halt_reg = 0xb80b4, 6325 .halt_check = BRANCH_HALT_DELAY, 6326 .clkr = { 6327 .enable_reg = 0xb80b4, 6328 .enable_mask = BIT(0), 6329 .hw.init = &(const struct clk_init_data) { 6330 .name = "gcc_usb4_1_phy_p2rr2p_pipe_clk", 6331 .parent_hws = (const struct clk_hw*[]){ 6332 &gcc_usb4_1_phy_p2rr2p_pipe_clk_src.clkr.hw, 6333 }, 6334 .num_parents = 1, 6335 .flags = CLK_SET_RATE_PARENT, 6336 .ops = &clk_branch2_ops, 6337 }, 6338 }, 6339 }; 6340 6341 static struct clk_branch gcc_usb4_1_phy_pcie_pipe_clk = { 6342 .halt_reg = 0xb8038, 6343 .halt_check = BRANCH_HALT_DELAY, 6344 .clkr = { 6345 .enable_reg = 0x52020, 6346 .enable_mask = BIT(19), 6347 .hw.init = &(const struct clk_init_data) { 6348 .name = "gcc_usb4_1_phy_pcie_pipe_clk", 6349 .parent_hws = (const struct clk_hw*[]){ 6350 &gcc_usb4_1_phy_pcie_pipe_mux_clk_src.clkr.hw, 6351 }, 6352 .num_parents = 1, 6353 .flags = CLK_SET_RATE_PARENT, 6354 .ops = &clk_branch2_ops, 6355 }, 6356 }, 6357 }; 6358 6359 static struct clk_branch gcc_usb4_1_phy_rx0_clk = { 6360 .halt_reg = 0xb8094, 6361 .halt_check = BRANCH_HALT, 6362 .clkr = { 6363 .enable_reg = 0xb8094, 6364 .enable_mask = BIT(0), 6365 .hw.init = &(const struct clk_init_data) { 6366 .name = "gcc_usb4_1_phy_rx0_clk", 6367 .parent_hws = (const struct clk_hw*[]){ 6368 &gcc_usb4_1_phy_rx0_clk_src.clkr.hw, 6369 }, 6370 .num_parents = 1, 6371 .flags = CLK_SET_RATE_PARENT, 6372 .ops = &clk_branch2_ops, 6373 }, 6374 }, 6375 }; 6376 6377 static struct clk_branch gcc_usb4_1_phy_rx1_clk = { 6378 .halt_reg = 0xb80a0, 6379 .halt_check = BRANCH_HALT, 6380 .clkr = { 6381 .enable_reg = 0xb80a0, 6382 .enable_mask = BIT(0), 6383 .hw.init = &(const struct clk_init_data) { 6384 .name = "gcc_usb4_1_phy_rx1_clk", 6385 .parent_hws = (const struct clk_hw*[]){ 6386 &gcc_usb4_1_phy_rx1_clk_src.clkr.hw, 6387 }, 6388 .num_parents = 1, 6389 .flags = CLK_SET_RATE_PARENT, 6390 .ops = &clk_branch2_ops, 6391 }, 6392 }, 6393 }; 6394 6395 static struct clk_branch gcc_usb4_1_phy_usb_pipe_clk = { 6396 .halt_reg = 0xb8088, 6397 .halt_check = BRANCH_HALT_DELAY, 6398 .hwcg_reg = 0xb8088, 6399 .hwcg_bit = 1, 6400 .clkr = { 6401 .enable_reg = 0xb8088, 6402 .enable_mask = BIT(0), 6403 .hw.init = &(const struct clk_init_data) { 6404 .name = "gcc_usb4_1_phy_usb_pipe_clk", 6405 .parent_hws = (const struct clk_hw*[]){ 6406 &gcc_usb34_sec_phy_pipe_clk_src.clkr.hw, 6407 }, 6408 .num_parents = 1, 6409 .flags = CLK_SET_RATE_PARENT, 6410 .ops = &clk_branch2_ops, 6411 }, 6412 }, 6413 }; 6414 6415 static struct clk_branch gcc_usb4_1_sb_if_clk = { 6416 .halt_reg = 0xb8034, 6417 .halt_check = BRANCH_HALT, 6418 .clkr = { 6419 .enable_reg = 0xb8034, 6420 .enable_mask = BIT(0), 6421 .hw.init = &(const struct clk_init_data) { 6422 .name = "gcc_usb4_1_sb_if_clk", 6423 .parent_hws = (const struct clk_hw*[]){ 6424 &gcc_usb4_1_sb_if_clk_src.clkr.hw, 6425 }, 6426 .num_parents = 1, 6427 .flags = CLK_SET_RATE_PARENT, 6428 .ops = &clk_branch2_ops, 6429 }, 6430 }, 6431 }; 6432 6433 static struct clk_branch gcc_usb4_1_sys_clk = { 6434 .halt_reg = 0xb8040, 6435 .halt_check = BRANCH_HALT, 6436 .clkr = { 6437 .enable_reg = 0xb8040, 6438 .enable_mask = BIT(0), 6439 .hw.init = &(const struct clk_init_data) { 6440 .name = "gcc_usb4_1_sys_clk", 6441 .parent_hws = (const struct clk_hw*[]){ 6442 &gcc_usb4_1_phy_sys_clk_src.clkr.hw, 6443 }, 6444 .num_parents = 1, 6445 .flags = CLK_SET_RATE_PARENT, 6446 .ops = &clk_branch2_ops, 6447 }, 6448 }, 6449 }; 6450 6451 static struct clk_branch gcc_usb4_1_tmu_clk = { 6452 .halt_reg = 0xb806c, 6453 .halt_check = BRANCH_HALT_VOTED, 6454 .hwcg_reg = 0xb806c, 6455 .hwcg_bit = 1, 6456 .clkr = { 6457 .enable_reg = 0xb806c, 6458 .enable_mask = BIT(0), 6459 .hw.init = &(const struct clk_init_data) { 6460 .name = "gcc_usb4_1_tmu_clk", 6461 .parent_hws = (const struct clk_hw*[]){ 6462 &gcc_usb4_1_tmu_clk_src.clkr.hw, 6463 }, 6464 .num_parents = 1, 6465 .flags = CLK_SET_RATE_PARENT, 6466 .ops = &clk_branch2_ops, 6467 }, 6468 }, 6469 }; 6470 6471 static struct clk_branch gcc_usb4_cfg_ahb_clk = { 6472 .halt_reg = 0x2a08c, 6473 .halt_check = BRANCH_HALT_VOTED, 6474 .hwcg_reg = 0x2a08c, 6475 .hwcg_bit = 1, 6476 .clkr = { 6477 .enable_reg = 0x2a08c, 6478 .enable_mask = BIT(0), 6479 .hw.init = &(const struct clk_init_data) { 6480 .name = "gcc_usb4_cfg_ahb_clk", 6481 .ops = &clk_branch2_ops, 6482 }, 6483 }, 6484 }; 6485 6486 static struct clk_branch gcc_usb4_clkref_clk = { 6487 .halt_reg = 0x8c010, 6488 .halt_check = BRANCH_HALT, 6489 .clkr = { 6490 .enable_reg = 0x8c010, 6491 .enable_mask = BIT(0), 6492 .hw.init = &(const struct clk_init_data) { 6493 .name = "gcc_usb4_clkref_clk", 6494 .ops = &clk_branch2_ops, 6495 }, 6496 }, 6497 }; 6498 6499 static struct clk_branch gcc_usb4_dp_clk = { 6500 .halt_reg = 0x2a048, 6501 .halt_check = BRANCH_HALT, 6502 .clkr = { 6503 .enable_reg = 0x2a048, 6504 .enable_mask = BIT(0), 6505 .hw.init = &(const struct clk_init_data) { 6506 .name = "gcc_usb4_dp_clk", 6507 .parent_hws = (const struct clk_hw*[]){ 6508 &gcc_usb4_phy_dp_clk_src.clkr.hw, 6509 }, 6510 .num_parents = 1, 6511 .flags = CLK_SET_RATE_PARENT, 6512 .ops = &clk_branch2_ops, 6513 }, 6514 }, 6515 }; 6516 6517 static struct clk_branch gcc_usb4_eud_clkref_clk = { 6518 .halt_reg = 0x8c02c, 6519 .halt_check = BRANCH_HALT, 6520 .clkr = { 6521 .enable_reg = 0x8c02c, 6522 .enable_mask = BIT(0), 6523 .hw.init = &(const struct clk_init_data) { 6524 .name = "gcc_usb4_eud_clkref_clk", 6525 .ops = &clk_branch2_ops, 6526 }, 6527 }, 6528 }; 6529 6530 static struct clk_branch gcc_usb4_master_clk = { 6531 .halt_reg = 0x2a010, 6532 .halt_check = BRANCH_HALT, 6533 .clkr = { 6534 .enable_reg = 0x2a010, 6535 .enable_mask = BIT(0), 6536 .hw.init = &(const struct clk_init_data) { 6537 .name = "gcc_usb4_master_clk", 6538 .parent_hws = (const struct clk_hw*[]){ 6539 &gcc_usb4_master_clk_src.clkr.hw, 6540 }, 6541 .num_parents = 1, 6542 .flags = CLK_SET_RATE_PARENT, 6543 .ops = &clk_branch2_ops, 6544 }, 6545 }, 6546 }; 6547 6548 static struct clk_branch gcc_usb4_phy_p2rr2p_pipe_clk = { 6549 .halt_reg = 0x2a0b4, 6550 .halt_check = BRANCH_HALT_DELAY, 6551 .clkr = { 6552 .enable_reg = 0x2a0b4, 6553 .enable_mask = BIT(0), 6554 .hw.init = &(const struct clk_init_data) { 6555 .name = "gcc_usb4_phy_p2rr2p_pipe_clk", 6556 .parent_hws = (const struct clk_hw*[]){ 6557 &gcc_usb4_phy_p2rr2p_pipe_clk_src.clkr.hw, 6558 }, 6559 .num_parents = 1, 6560 .flags = CLK_SET_RATE_PARENT, 6561 .ops = &clk_branch2_ops, 6562 }, 6563 }, 6564 }; 6565 6566 static struct clk_branch gcc_usb4_phy_pcie_pipe_clk = { 6567 .halt_reg = 0x2a038, 6568 .halt_check = BRANCH_HALT_DELAY, 6569 .clkr = { 6570 .enable_reg = 0x52020, 6571 .enable_mask = BIT(18), 6572 .hw.init = &(const struct clk_init_data) { 6573 .name = "gcc_usb4_phy_pcie_pipe_clk", 6574 .parent_hws = (const struct clk_hw*[]){ 6575 &gcc_usb4_phy_pcie_pipe_mux_clk_src.clkr.hw, 6576 }, 6577 .num_parents = 1, 6578 .flags = CLK_SET_RATE_PARENT, 6579 .ops = &clk_branch2_ops, 6580 }, 6581 }, 6582 }; 6583 6584 static struct clk_branch gcc_usb4_phy_rx0_clk = { 6585 .halt_reg = 0x2a094, 6586 .halt_check = BRANCH_HALT, 6587 .clkr = { 6588 .enable_reg = 0x2a094, 6589 .enable_mask = BIT(0), 6590 .hw.init = &(const struct clk_init_data) { 6591 .name = "gcc_usb4_phy_rx0_clk", 6592 .parent_hws = (const struct clk_hw*[]){ 6593 &gcc_usb4_phy_rx0_clk_src.clkr.hw, 6594 }, 6595 .num_parents = 1, 6596 .flags = CLK_SET_RATE_PARENT, 6597 .ops = &clk_branch2_ops, 6598 }, 6599 }, 6600 }; 6601 6602 static struct clk_branch gcc_usb4_phy_rx1_clk = { 6603 .halt_reg = 0x2a0a0, 6604 .halt_check = BRANCH_HALT, 6605 .clkr = { 6606 .enable_reg = 0x2a0a0, 6607 .enable_mask = BIT(0), 6608 .hw.init = &(const struct clk_init_data) { 6609 .name = "gcc_usb4_phy_rx1_clk", 6610 .parent_hws = (const struct clk_hw*[]){ 6611 &gcc_usb4_phy_rx1_clk_src.clkr.hw, 6612 }, 6613 .num_parents = 1, 6614 .flags = CLK_SET_RATE_PARENT, 6615 .ops = &clk_branch2_ops, 6616 }, 6617 }, 6618 }; 6619 6620 static struct clk_branch gcc_usb4_phy_usb_pipe_clk = { 6621 .halt_reg = 0x2a088, 6622 .halt_check = BRANCH_HALT_DELAY, 6623 .hwcg_reg = 0x2a088, 6624 .hwcg_bit = 1, 6625 .clkr = { 6626 .enable_reg = 0x2a088, 6627 .enable_mask = BIT(0), 6628 .hw.init = &(const struct clk_init_data) { 6629 .name = "gcc_usb4_phy_usb_pipe_clk", 6630 .parent_hws = (const struct clk_hw*[]){ 6631 &gcc_usb34_prim_phy_pipe_clk_src.clkr.hw, 6632 }, 6633 .num_parents = 1, 6634 .flags = CLK_SET_RATE_PARENT, 6635 .ops = &clk_branch2_ops, 6636 }, 6637 }, 6638 }; 6639 6640 static struct clk_branch gcc_usb4_sb_if_clk = { 6641 .halt_reg = 0x2a034, 6642 .halt_check = BRANCH_HALT, 6643 .clkr = { 6644 .enable_reg = 0x2a034, 6645 .enable_mask = BIT(0), 6646 .hw.init = &(const struct clk_init_data) { 6647 .name = "gcc_usb4_sb_if_clk", 6648 .parent_hws = (const struct clk_hw*[]){ 6649 &gcc_usb4_sb_if_clk_src.clkr.hw, 6650 }, 6651 .num_parents = 1, 6652 .flags = CLK_SET_RATE_PARENT, 6653 .ops = &clk_branch2_ops, 6654 }, 6655 }, 6656 }; 6657 6658 static struct clk_branch gcc_usb4_sys_clk = { 6659 .halt_reg = 0x2a040, 6660 .halt_check = BRANCH_HALT, 6661 .clkr = { 6662 .enable_reg = 0x2a040, 6663 .enable_mask = BIT(0), 6664 .hw.init = &(const struct clk_init_data) { 6665 .name = "gcc_usb4_sys_clk", 6666 .parent_hws = (const struct clk_hw*[]){ 6667 &gcc_usb4_phy_sys_clk_src.clkr.hw, 6668 }, 6669 .num_parents = 1, 6670 .flags = CLK_SET_RATE_PARENT, 6671 .ops = &clk_branch2_ops, 6672 }, 6673 }, 6674 }; 6675 6676 static struct clk_branch gcc_usb4_tmu_clk = { 6677 .halt_reg = 0x2a06c, 6678 .halt_check = BRANCH_HALT_VOTED, 6679 .hwcg_reg = 0x2a06c, 6680 .hwcg_bit = 1, 6681 .clkr = { 6682 .enable_reg = 0x2a06c, 6683 .enable_mask = BIT(0), 6684 .hw.init = &(const struct clk_init_data) { 6685 .name = "gcc_usb4_tmu_clk", 6686 .parent_hws = (const struct clk_hw*[]){ 6687 &gcc_usb4_tmu_clk_src.clkr.hw, 6688 }, 6689 .num_parents = 1, 6690 .flags = CLK_SET_RATE_PARENT, 6691 .ops = &clk_branch2_ops, 6692 }, 6693 }, 6694 }; 6695 6696 static struct clk_branch gcc_video_axi0_clk = { 6697 .halt_reg = 0x28010, 6698 .halt_check = BRANCH_HALT_SKIP, 6699 .hwcg_reg = 0x28010, 6700 .hwcg_bit = 1, 6701 .clkr = { 6702 .enable_reg = 0x28010, 6703 .enable_mask = BIT(0), 6704 .hw.init = &(const struct clk_init_data) { 6705 .name = "gcc_video_axi0_clk", 6706 .ops = &clk_branch2_ops, 6707 }, 6708 }, 6709 }; 6710 6711 static struct clk_branch gcc_video_axi1_clk = { 6712 .halt_reg = 0x28018, 6713 .halt_check = BRANCH_HALT_SKIP, 6714 .hwcg_reg = 0x28018, 6715 .hwcg_bit = 1, 6716 .clkr = { 6717 .enable_reg = 0x28018, 6718 .enable_mask = BIT(0), 6719 .hw.init = &(const struct clk_init_data) { 6720 .name = "gcc_video_axi1_clk", 6721 .ops = &clk_branch2_ops, 6722 }, 6723 }, 6724 }; 6725 6726 static struct clk_branch gcc_video_cvp_throttle_clk = { 6727 .halt_reg = 0x28024, 6728 .halt_check = BRANCH_HALT_SKIP, 6729 .hwcg_reg = 0x28024, 6730 .hwcg_bit = 1, 6731 .clkr = { 6732 .enable_reg = 0x28024, 6733 .enable_mask = BIT(0), 6734 .hw.init = &(const struct clk_init_data) { 6735 .name = "gcc_video_cvp_throttle_clk", 6736 .ops = &clk_branch2_ops, 6737 }, 6738 }, 6739 }; 6740 6741 static struct clk_branch gcc_video_vcodec_throttle_clk = { 6742 .halt_reg = 0x28020, 6743 .halt_check = BRANCH_HALT_SKIP, 6744 .hwcg_reg = 0x28020, 6745 .hwcg_bit = 1, 6746 .clkr = { 6747 .enable_reg = 0x28020, 6748 .enable_mask = BIT(0), 6749 .hw.init = &(const struct clk_init_data) { 6750 .name = "gcc_video_vcodec_throttle_clk", 6751 .ops = &clk_branch2_ops, 6752 }, 6753 }, 6754 }; 6755 6756 static struct gdsc pcie_0_tunnel_gdsc = { 6757 .gdscr = 0xa4004, 6758 .collapse_ctrl = 0x52128, 6759 .collapse_mask = BIT(0), 6760 .pd = { 6761 .name = "pcie_0_tunnel_gdsc", 6762 }, 6763 .pwrsts = PWRSTS_OFF_ON, 6764 .flags = VOTABLE | RETAIN_FF_ENABLE, 6765 }; 6766 6767 static struct gdsc pcie_1_tunnel_gdsc = { 6768 .gdscr = 0x8d004, 6769 .collapse_ctrl = 0x52128, 6770 .collapse_mask = BIT(1), 6771 .pd = { 6772 .name = "pcie_1_tunnel_gdsc", 6773 }, 6774 .pwrsts = PWRSTS_OFF_ON, 6775 .flags = VOTABLE | RETAIN_FF_ENABLE, 6776 }; 6777 6778 /* 6779 * The Qualcomm PCIe driver does not yet implement suspend so to keep the 6780 * PCIe power domains always-on for now. 6781 */ 6782 static struct gdsc pcie_2a_gdsc = { 6783 .gdscr = 0x9d004, 6784 .collapse_ctrl = 0x52128, 6785 .collapse_mask = BIT(2), 6786 .pd = { 6787 .name = "pcie_2a_gdsc", 6788 }, 6789 .pwrsts = PWRSTS_RET_ON, 6790 .flags = VOTABLE | RETAIN_FF_ENABLE, 6791 }; 6792 6793 static struct gdsc pcie_2b_gdsc = { 6794 .gdscr = 0x9e004, 6795 .collapse_ctrl = 0x52128, 6796 .collapse_mask = BIT(3), 6797 .pd = { 6798 .name = "pcie_2b_gdsc", 6799 }, 6800 .pwrsts = PWRSTS_RET_ON, 6801 .flags = VOTABLE | RETAIN_FF_ENABLE, 6802 }; 6803 6804 static struct gdsc pcie_3a_gdsc = { 6805 .gdscr = 0xa0004, 6806 .collapse_ctrl = 0x52128, 6807 .collapse_mask = BIT(4), 6808 .pd = { 6809 .name = "pcie_3a_gdsc", 6810 }, 6811 .pwrsts = PWRSTS_RET_ON, 6812 .flags = VOTABLE | RETAIN_FF_ENABLE, 6813 }; 6814 6815 static struct gdsc pcie_3b_gdsc = { 6816 .gdscr = 0xa2004, 6817 .collapse_ctrl = 0x52128, 6818 .collapse_mask = BIT(5), 6819 .pd = { 6820 .name = "pcie_3b_gdsc", 6821 }, 6822 .pwrsts = PWRSTS_RET_ON, 6823 .flags = VOTABLE | RETAIN_FF_ENABLE, 6824 }; 6825 6826 static struct gdsc pcie_4_gdsc = { 6827 .gdscr = 0x6b004, 6828 .collapse_ctrl = 0x52128, 6829 .collapse_mask = BIT(6), 6830 .pd = { 6831 .name = "pcie_4_gdsc", 6832 }, 6833 .pwrsts = PWRSTS_RET_ON, 6834 .flags = VOTABLE | RETAIN_FF_ENABLE, 6835 }; 6836 6837 static struct gdsc ufs_card_gdsc = { 6838 .gdscr = 0x75004, 6839 .pd = { 6840 .name = "ufs_card_gdsc", 6841 }, 6842 .pwrsts = PWRSTS_OFF_ON, 6843 .flags = RETAIN_FF_ENABLE, 6844 }; 6845 6846 static struct gdsc ufs_phy_gdsc = { 6847 .gdscr = 0x77004, 6848 .pd = { 6849 .name = "ufs_phy_gdsc", 6850 }, 6851 .pwrsts = PWRSTS_OFF_ON, 6852 .flags = RETAIN_FF_ENABLE, 6853 }; 6854 6855 static struct gdsc usb30_mp_gdsc = { 6856 .gdscr = 0xab004, 6857 .pd = { 6858 .name = "usb30_mp_gdsc", 6859 }, 6860 .pwrsts = PWRSTS_RET_ON, 6861 .flags = RETAIN_FF_ENABLE, 6862 }; 6863 6864 static struct gdsc usb30_prim_gdsc = { 6865 .gdscr = 0xf004, 6866 .pd = { 6867 .name = "usb30_prim_gdsc", 6868 }, 6869 .pwrsts = PWRSTS_RET_ON, 6870 .flags = RETAIN_FF_ENABLE, 6871 }; 6872 6873 static struct gdsc usb30_sec_gdsc = { 6874 .gdscr = 0x10004, 6875 .pd = { 6876 .name = "usb30_sec_gdsc", 6877 }, 6878 .pwrsts = PWRSTS_RET_ON, 6879 .flags = RETAIN_FF_ENABLE, 6880 }; 6881 6882 static struct gdsc emac_0_gdsc = { 6883 .gdscr = 0xaa004, 6884 .pd = { 6885 .name = "emac_0_gdsc", 6886 }, 6887 .pwrsts = PWRSTS_OFF_ON, 6888 .flags = RETAIN_FF_ENABLE, 6889 }; 6890 6891 static struct gdsc emac_1_gdsc = { 6892 .gdscr = 0xba004, 6893 .pd = { 6894 .name = "emac_1_gdsc", 6895 }, 6896 .pwrsts = PWRSTS_OFF_ON, 6897 .flags = RETAIN_FF_ENABLE, 6898 }; 6899 6900 static struct gdsc usb4_1_gdsc = { 6901 .gdscr = 0xb8004, 6902 .pd = { 6903 .name = "usb4_1_gdsc", 6904 }, 6905 .pwrsts = PWRSTS_OFF_ON, 6906 .flags = RETAIN_FF_ENABLE, 6907 }; 6908 6909 static struct gdsc usb4_gdsc = { 6910 .gdscr = 0x2a004, 6911 .pd = { 6912 .name = "usb4_gdsc", 6913 }, 6914 .pwrsts = PWRSTS_OFF_ON, 6915 .flags = RETAIN_FF_ENABLE, 6916 }; 6917 6918 static struct gdsc hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc = { 6919 .gdscr = 0x7d050, 6920 .pd = { 6921 .name = "hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc", 6922 }, 6923 .pwrsts = PWRSTS_OFF_ON, 6924 .flags = VOTABLE, 6925 }; 6926 6927 static struct gdsc hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc = { 6928 .gdscr = 0x7d058, 6929 .pd = { 6930 .name = "hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc", 6931 }, 6932 .pwrsts = PWRSTS_OFF_ON, 6933 .flags = VOTABLE, 6934 }; 6935 6936 static struct gdsc hlos1_vote_mmnoc_mmu_tbu_sf0_gdsc = { 6937 .gdscr = 0x7d054, 6938 .pd = { 6939 .name = "hlos1_vote_mmnoc_mmu_tbu_sf0_gdsc", 6940 }, 6941 .pwrsts = PWRSTS_OFF_ON, 6942 .flags = VOTABLE, 6943 }; 6944 6945 static struct gdsc hlos1_vote_mmnoc_mmu_tbu_sf1_gdsc = { 6946 .gdscr = 0x7d06c, 6947 .pd = { 6948 .name = "hlos1_vote_mmnoc_mmu_tbu_sf1_gdsc", 6949 }, 6950 .pwrsts = PWRSTS_OFF_ON, 6951 .flags = VOTABLE, 6952 }; 6953 6954 static struct gdsc hlos1_vote_turing_mmu_tbu0_gdsc = { 6955 .gdscr = 0x7d05c, 6956 .pd = { 6957 .name = "hlos1_vote_turing_mmu_tbu0_gdsc", 6958 }, 6959 .pwrsts = PWRSTS_OFF_ON, 6960 .flags = VOTABLE, 6961 }; 6962 6963 static struct gdsc hlos1_vote_turing_mmu_tbu1_gdsc = { 6964 .gdscr = 0x7d060, 6965 .pd = { 6966 .name = "hlos1_vote_turing_mmu_tbu1_gdsc", 6967 }, 6968 .pwrsts = PWRSTS_OFF_ON, 6969 .flags = VOTABLE, 6970 }; 6971 6972 static struct gdsc hlos1_vote_turing_mmu_tbu2_gdsc = { 6973 .gdscr = 0x7d0a0, 6974 .pd = { 6975 .name = "hlos1_vote_turing_mmu_tbu2_gdsc", 6976 }, 6977 .pwrsts = PWRSTS_OFF_ON, 6978 .flags = VOTABLE, 6979 }; 6980 6981 static struct gdsc hlos1_vote_turing_mmu_tbu3_gdsc = { 6982 .gdscr = 0x7d0a4, 6983 .pd = { 6984 .name = "hlos1_vote_turing_mmu_tbu3_gdsc", 6985 }, 6986 .pwrsts = PWRSTS_OFF_ON, 6987 .flags = VOTABLE, 6988 }; 6989 6990 static struct clk_regmap *gcc_sc8280xp_clocks[] = { 6991 [GCC_AGGRE_NOC_PCIE0_TUNNEL_AXI_CLK] = &gcc_aggre_noc_pcie0_tunnel_axi_clk.clkr, 6992 [GCC_AGGRE_NOC_PCIE1_TUNNEL_AXI_CLK] = &gcc_aggre_noc_pcie1_tunnel_axi_clk.clkr, 6993 [GCC_AGGRE_NOC_PCIE_4_AXI_CLK] = &gcc_aggre_noc_pcie_4_axi_clk.clkr, 6994 [GCC_AGGRE_NOC_PCIE_SOUTH_SF_AXI_CLK] = &gcc_aggre_noc_pcie_south_sf_axi_clk.clkr, 6995 [GCC_AGGRE_UFS_CARD_AXI_CLK] = &gcc_aggre_ufs_card_axi_clk.clkr, 6996 [GCC_AGGRE_UFS_CARD_AXI_HW_CTL_CLK] = &gcc_aggre_ufs_card_axi_hw_ctl_clk.clkr, 6997 [GCC_AGGRE_UFS_PHY_AXI_CLK] = &gcc_aggre_ufs_phy_axi_clk.clkr, 6998 [GCC_AGGRE_UFS_PHY_AXI_HW_CTL_CLK] = &gcc_aggre_ufs_phy_axi_hw_ctl_clk.clkr, 6999 [GCC_AGGRE_USB3_MP_AXI_CLK] = &gcc_aggre_usb3_mp_axi_clk.clkr, 7000 [GCC_AGGRE_USB3_PRIM_AXI_CLK] = &gcc_aggre_usb3_prim_axi_clk.clkr, 7001 [GCC_AGGRE_USB3_SEC_AXI_CLK] = &gcc_aggre_usb3_sec_axi_clk.clkr, 7002 [GCC_AGGRE_USB4_1_AXI_CLK] = &gcc_aggre_usb4_1_axi_clk.clkr, 7003 [GCC_AGGRE_USB4_AXI_CLK] = &gcc_aggre_usb4_axi_clk.clkr, 7004 [GCC_AGGRE_USB_NOC_AXI_CLK] = &gcc_aggre_usb_noc_axi_clk.clkr, 7005 [GCC_AGGRE_USB_NOC_NORTH_AXI_CLK] = &gcc_aggre_usb_noc_north_axi_clk.clkr, 7006 [GCC_AGGRE_USB_NOC_SOUTH_AXI_CLK] = &gcc_aggre_usb_noc_south_axi_clk.clkr, 7007 [GCC_AHB2PHY0_CLK] = &gcc_ahb2phy0_clk.clkr, 7008 [GCC_AHB2PHY2_CLK] = &gcc_ahb2phy2_clk.clkr, 7009 [GCC_BOOT_ROM_AHB_CLK] = &gcc_boot_rom_ahb_clk.clkr, 7010 [GCC_CAMERA_HF_AXI_CLK] = &gcc_camera_hf_axi_clk.clkr, 7011 [GCC_CAMERA_SF_AXI_CLK] = &gcc_camera_sf_axi_clk.clkr, 7012 [GCC_CAMERA_THROTTLE_NRT_AXI_CLK] = &gcc_camera_throttle_nrt_axi_clk.clkr, 7013 [GCC_CAMERA_THROTTLE_RT_AXI_CLK] = &gcc_camera_throttle_rt_axi_clk.clkr, 7014 [GCC_CAMERA_THROTTLE_XO_CLK] = &gcc_camera_throttle_xo_clk.clkr, 7015 [GCC_CFG_NOC_USB3_MP_AXI_CLK] = &gcc_cfg_noc_usb3_mp_axi_clk.clkr, 7016 [GCC_CFG_NOC_USB3_PRIM_AXI_CLK] = &gcc_cfg_noc_usb3_prim_axi_clk.clkr, 7017 [GCC_CFG_NOC_USB3_SEC_AXI_CLK] = &gcc_cfg_noc_usb3_sec_axi_clk.clkr, 7018 [GCC_CNOC_PCIE0_TUNNEL_CLK] = &gcc_cnoc_pcie0_tunnel_clk.clkr, 7019 [GCC_CNOC_PCIE1_TUNNEL_CLK] = &gcc_cnoc_pcie1_tunnel_clk.clkr, 7020 [GCC_CNOC_PCIE4_QX_CLK] = &gcc_cnoc_pcie4_qx_clk.clkr, 7021 [GCC_DDRSS_GPU_AXI_CLK] = &gcc_ddrss_gpu_axi_clk.clkr, 7022 [GCC_DDRSS_PCIE_SF_TBU_CLK] = &gcc_ddrss_pcie_sf_tbu_clk.clkr, 7023 [GCC_DISP1_HF_AXI_CLK] = &gcc_disp1_hf_axi_clk.clkr, 7024 [GCC_DISP1_SF_AXI_CLK] = &gcc_disp1_sf_axi_clk.clkr, 7025 [GCC_DISP1_THROTTLE_NRT_AXI_CLK] = &gcc_disp1_throttle_nrt_axi_clk.clkr, 7026 [GCC_DISP1_THROTTLE_RT_AXI_CLK] = &gcc_disp1_throttle_rt_axi_clk.clkr, 7027 [GCC_DISP_HF_AXI_CLK] = &gcc_disp_hf_axi_clk.clkr, 7028 [GCC_DISP_SF_AXI_CLK] = &gcc_disp_sf_axi_clk.clkr, 7029 [GCC_DISP_THROTTLE_NRT_AXI_CLK] = &gcc_disp_throttle_nrt_axi_clk.clkr, 7030 [GCC_DISP_THROTTLE_RT_AXI_CLK] = &gcc_disp_throttle_rt_axi_clk.clkr, 7031 [GCC_EMAC0_AXI_CLK] = &gcc_emac0_axi_clk.clkr, 7032 [GCC_EMAC0_PTP_CLK] = &gcc_emac0_ptp_clk.clkr, 7033 [GCC_EMAC0_PTP_CLK_SRC] = &gcc_emac0_ptp_clk_src.clkr, 7034 [GCC_EMAC0_RGMII_CLK] = &gcc_emac0_rgmii_clk.clkr, 7035 [GCC_EMAC0_RGMII_CLK_SRC] = &gcc_emac0_rgmii_clk_src.clkr, 7036 [GCC_EMAC0_SLV_AHB_CLK] = &gcc_emac0_slv_ahb_clk.clkr, 7037 [GCC_EMAC1_AXI_CLK] = &gcc_emac1_axi_clk.clkr, 7038 [GCC_EMAC1_PTP_CLK] = &gcc_emac1_ptp_clk.clkr, 7039 [GCC_EMAC1_PTP_CLK_SRC] = &gcc_emac1_ptp_clk_src.clkr, 7040 [GCC_EMAC1_RGMII_CLK] = &gcc_emac1_rgmii_clk.clkr, 7041 [GCC_EMAC1_RGMII_CLK_SRC] = &gcc_emac1_rgmii_clk_src.clkr, 7042 [GCC_EMAC1_SLV_AHB_CLK] = &gcc_emac1_slv_ahb_clk.clkr, 7043 [GCC_GP1_CLK] = &gcc_gp1_clk.clkr, 7044 [GCC_GP1_CLK_SRC] = &gcc_gp1_clk_src.clkr, 7045 [GCC_GP2_CLK] = &gcc_gp2_clk.clkr, 7046 [GCC_GP2_CLK_SRC] = &gcc_gp2_clk_src.clkr, 7047 [GCC_GP3_CLK] = &gcc_gp3_clk.clkr, 7048 [GCC_GP3_CLK_SRC] = &gcc_gp3_clk_src.clkr, 7049 [GCC_GP4_CLK] = &gcc_gp4_clk.clkr, 7050 [GCC_GP4_CLK_SRC] = &gcc_gp4_clk_src.clkr, 7051 [GCC_GP5_CLK] = &gcc_gp5_clk.clkr, 7052 [GCC_GP5_CLK_SRC] = &gcc_gp5_clk_src.clkr, 7053 [GCC_GPLL0] = &gcc_gpll0.clkr, 7054 [GCC_GPLL0_OUT_EVEN] = &gcc_gpll0_out_even.clkr, 7055 [GCC_GPLL2] = &gcc_gpll2.clkr, 7056 [GCC_GPLL4] = &gcc_gpll4.clkr, 7057 [GCC_GPLL7] = &gcc_gpll7.clkr, 7058 [GCC_GPLL8] = &gcc_gpll8.clkr, 7059 [GCC_GPLL9] = &gcc_gpll9.clkr, 7060 [GCC_GPU_GPLL0_CLK_SRC] = &gcc_gpu_gpll0_clk_src.clkr, 7061 [GCC_GPU_GPLL0_DIV_CLK_SRC] = &gcc_gpu_gpll0_div_clk_src.clkr, 7062 [GCC_GPU_IREF_EN] = &gcc_gpu_iref_en.clkr, 7063 [GCC_GPU_MEMNOC_GFX_CLK] = &gcc_gpu_memnoc_gfx_clk.clkr, 7064 [GCC_GPU_SNOC_DVM_GFX_CLK] = &gcc_gpu_snoc_dvm_gfx_clk.clkr, 7065 [GCC_GPU_TCU_THROTTLE_AHB_CLK] = &gcc_gpu_tcu_throttle_ahb_clk.clkr, 7066 [GCC_GPU_TCU_THROTTLE_CLK] = &gcc_gpu_tcu_throttle_clk.clkr, 7067 [GCC_PCIE0_PHY_RCHNG_CLK] = &gcc_pcie0_phy_rchng_clk.clkr, 7068 [GCC_PCIE1_PHY_RCHNG_CLK] = &gcc_pcie1_phy_rchng_clk.clkr, 7069 [GCC_PCIE2A_PHY_RCHNG_CLK] = &gcc_pcie2a_phy_rchng_clk.clkr, 7070 [GCC_PCIE2B_PHY_RCHNG_CLK] = &gcc_pcie2b_phy_rchng_clk.clkr, 7071 [GCC_PCIE3A_PHY_RCHNG_CLK] = &gcc_pcie3a_phy_rchng_clk.clkr, 7072 [GCC_PCIE3B_PHY_RCHNG_CLK] = &gcc_pcie3b_phy_rchng_clk.clkr, 7073 [GCC_PCIE4_PHY_RCHNG_CLK] = &gcc_pcie4_phy_rchng_clk.clkr, 7074 [GCC_PCIE_0_AUX_CLK] = &gcc_pcie_0_aux_clk.clkr, 7075 [GCC_PCIE_0_AUX_CLK_SRC] = &gcc_pcie_0_aux_clk_src.clkr, 7076 [GCC_PCIE_0_CFG_AHB_CLK] = &gcc_pcie_0_cfg_ahb_clk.clkr, 7077 [GCC_PCIE_0_MSTR_AXI_CLK] = &gcc_pcie_0_mstr_axi_clk.clkr, 7078 [GCC_PCIE_0_PHY_RCHNG_CLK_SRC] = &gcc_pcie_0_phy_rchng_clk_src.clkr, 7079 [GCC_PCIE_0_PIPE_CLK] = &gcc_pcie_0_pipe_clk.clkr, 7080 [GCC_PCIE_0_SLV_AXI_CLK] = &gcc_pcie_0_slv_axi_clk.clkr, 7081 [GCC_PCIE_0_SLV_Q2A_AXI_CLK] = &gcc_pcie_0_slv_q2a_axi_clk.clkr, 7082 [GCC_PCIE_1_AUX_CLK] = &gcc_pcie_1_aux_clk.clkr, 7083 [GCC_PCIE_1_AUX_CLK_SRC] = &gcc_pcie_1_aux_clk_src.clkr, 7084 [GCC_PCIE_1_CFG_AHB_CLK] = &gcc_pcie_1_cfg_ahb_clk.clkr, 7085 [GCC_PCIE_1_MSTR_AXI_CLK] = &gcc_pcie_1_mstr_axi_clk.clkr, 7086 [GCC_PCIE_1_PHY_RCHNG_CLK_SRC] = &gcc_pcie_1_phy_rchng_clk_src.clkr, 7087 [GCC_PCIE_1_PIPE_CLK] = &gcc_pcie_1_pipe_clk.clkr, 7088 [GCC_PCIE_1_SLV_AXI_CLK] = &gcc_pcie_1_slv_axi_clk.clkr, 7089 [GCC_PCIE_1_SLV_Q2A_AXI_CLK] = &gcc_pcie_1_slv_q2a_axi_clk.clkr, 7090 [GCC_PCIE_2A2B_CLKREF_CLK] = &gcc_pcie_2a2b_clkref_clk.clkr, 7091 [GCC_PCIE_2A_AUX_CLK] = &gcc_pcie_2a_aux_clk.clkr, 7092 [GCC_PCIE_2A_AUX_CLK_SRC] = &gcc_pcie_2a_aux_clk_src.clkr, 7093 [GCC_PCIE_2A_CFG_AHB_CLK] = &gcc_pcie_2a_cfg_ahb_clk.clkr, 7094 [GCC_PCIE_2A_MSTR_AXI_CLK] = &gcc_pcie_2a_mstr_axi_clk.clkr, 7095 [GCC_PCIE_2A_PHY_RCHNG_CLK_SRC] = &gcc_pcie_2a_phy_rchng_clk_src.clkr, 7096 [GCC_PCIE_2A_PIPE_CLK] = &gcc_pcie_2a_pipe_clk.clkr, 7097 [GCC_PCIE_2A_PIPE_CLK_SRC] = &gcc_pcie_2a_pipe_clk_src.clkr, 7098 [GCC_PCIE_2A_PIPE_DIV_CLK_SRC] = &gcc_pcie_2a_pipe_div_clk_src.clkr, 7099 [GCC_PCIE_2A_PIPEDIV2_CLK] = &gcc_pcie_2a_pipediv2_clk.clkr, 7100 [GCC_PCIE_2A_SLV_AXI_CLK] = &gcc_pcie_2a_slv_axi_clk.clkr, 7101 [GCC_PCIE_2A_SLV_Q2A_AXI_CLK] = &gcc_pcie_2a_slv_q2a_axi_clk.clkr, 7102 [GCC_PCIE_2B_AUX_CLK] = &gcc_pcie_2b_aux_clk.clkr, 7103 [GCC_PCIE_2B_AUX_CLK_SRC] = &gcc_pcie_2b_aux_clk_src.clkr, 7104 [GCC_PCIE_2B_CFG_AHB_CLK] = &gcc_pcie_2b_cfg_ahb_clk.clkr, 7105 [GCC_PCIE_2B_MSTR_AXI_CLK] = &gcc_pcie_2b_mstr_axi_clk.clkr, 7106 [GCC_PCIE_2B_PHY_RCHNG_CLK_SRC] = &gcc_pcie_2b_phy_rchng_clk_src.clkr, 7107 [GCC_PCIE_2B_PIPE_CLK] = &gcc_pcie_2b_pipe_clk.clkr, 7108 [GCC_PCIE_2B_PIPE_CLK_SRC] = &gcc_pcie_2b_pipe_clk_src.clkr, 7109 [GCC_PCIE_2B_PIPE_DIV_CLK_SRC] = &gcc_pcie_2b_pipe_div_clk_src.clkr, 7110 [GCC_PCIE_2B_PIPEDIV2_CLK] = &gcc_pcie_2b_pipediv2_clk.clkr, 7111 [GCC_PCIE_2B_SLV_AXI_CLK] = &gcc_pcie_2b_slv_axi_clk.clkr, 7112 [GCC_PCIE_2B_SLV_Q2A_AXI_CLK] = &gcc_pcie_2b_slv_q2a_axi_clk.clkr, 7113 [GCC_PCIE_3A3B_CLKREF_CLK] = &gcc_pcie_3a3b_clkref_clk.clkr, 7114 [GCC_PCIE_3A_AUX_CLK] = &gcc_pcie_3a_aux_clk.clkr, 7115 [GCC_PCIE_3A_AUX_CLK_SRC] = &gcc_pcie_3a_aux_clk_src.clkr, 7116 [GCC_PCIE_3A_CFG_AHB_CLK] = &gcc_pcie_3a_cfg_ahb_clk.clkr, 7117 [GCC_PCIE_3A_MSTR_AXI_CLK] = &gcc_pcie_3a_mstr_axi_clk.clkr, 7118 [GCC_PCIE_3A_PHY_RCHNG_CLK_SRC] = &gcc_pcie_3a_phy_rchng_clk_src.clkr, 7119 [GCC_PCIE_3A_PIPE_CLK] = &gcc_pcie_3a_pipe_clk.clkr, 7120 [GCC_PCIE_3A_PIPE_CLK_SRC] = &gcc_pcie_3a_pipe_clk_src.clkr, 7121 [GCC_PCIE_3A_PIPE_DIV_CLK_SRC] = &gcc_pcie_3a_pipe_div_clk_src.clkr, 7122 [GCC_PCIE_3A_PIPEDIV2_CLK] = &gcc_pcie_3a_pipediv2_clk.clkr, 7123 [GCC_PCIE_3A_SLV_AXI_CLK] = &gcc_pcie_3a_slv_axi_clk.clkr, 7124 [GCC_PCIE_3A_SLV_Q2A_AXI_CLK] = &gcc_pcie_3a_slv_q2a_axi_clk.clkr, 7125 [GCC_PCIE_3B_AUX_CLK] = &gcc_pcie_3b_aux_clk.clkr, 7126 [GCC_PCIE_3B_AUX_CLK_SRC] = &gcc_pcie_3b_aux_clk_src.clkr, 7127 [GCC_PCIE_3B_CFG_AHB_CLK] = &gcc_pcie_3b_cfg_ahb_clk.clkr, 7128 [GCC_PCIE_3B_MSTR_AXI_CLK] = &gcc_pcie_3b_mstr_axi_clk.clkr, 7129 [GCC_PCIE_3B_PHY_RCHNG_CLK_SRC] = &gcc_pcie_3b_phy_rchng_clk_src.clkr, 7130 [GCC_PCIE_3B_PIPE_CLK] = &gcc_pcie_3b_pipe_clk.clkr, 7131 [GCC_PCIE_3B_PIPE_CLK_SRC] = &gcc_pcie_3b_pipe_clk_src.clkr, 7132 [GCC_PCIE_3B_PIPE_DIV_CLK_SRC] = &gcc_pcie_3b_pipe_div_clk_src.clkr, 7133 [GCC_PCIE_3B_PIPEDIV2_CLK] = &gcc_pcie_3b_pipediv2_clk.clkr, 7134 [GCC_PCIE_3B_SLV_AXI_CLK] = &gcc_pcie_3b_slv_axi_clk.clkr, 7135 [GCC_PCIE_3B_SLV_Q2A_AXI_CLK] = &gcc_pcie_3b_slv_q2a_axi_clk.clkr, 7136 [GCC_PCIE_4_AUX_CLK] = &gcc_pcie_4_aux_clk.clkr, 7137 [GCC_PCIE_4_AUX_CLK_SRC] = &gcc_pcie_4_aux_clk_src.clkr, 7138 [GCC_PCIE_4_CFG_AHB_CLK] = &gcc_pcie_4_cfg_ahb_clk.clkr, 7139 [GCC_PCIE_4_CLKREF_CLK] = &gcc_pcie_4_clkref_clk.clkr, 7140 [GCC_PCIE_4_MSTR_AXI_CLK] = &gcc_pcie_4_mstr_axi_clk.clkr, 7141 [GCC_PCIE_4_PHY_RCHNG_CLK_SRC] = &gcc_pcie_4_phy_rchng_clk_src.clkr, 7142 [GCC_PCIE_4_PIPE_CLK] = &gcc_pcie_4_pipe_clk.clkr, 7143 [GCC_PCIE_4_PIPE_CLK_SRC] = &gcc_pcie_4_pipe_clk_src.clkr, 7144 [GCC_PCIE_4_PIPE_DIV_CLK_SRC] = &gcc_pcie_4_pipe_div_clk_src.clkr, 7145 [GCC_PCIE_4_PIPEDIV2_CLK] = &gcc_pcie_4_pipediv2_clk.clkr, 7146 [GCC_PCIE_4_SLV_AXI_CLK] = &gcc_pcie_4_slv_axi_clk.clkr, 7147 [GCC_PCIE_4_SLV_Q2A_AXI_CLK] = &gcc_pcie_4_slv_q2a_axi_clk.clkr, 7148 [GCC_PCIE_RSCC_AHB_CLK] = &gcc_pcie_rscc_ahb_clk.clkr, 7149 [GCC_PCIE_RSCC_XO_CLK] = &gcc_pcie_rscc_xo_clk.clkr, 7150 [GCC_PCIE_RSCC_XO_CLK_SRC] = &gcc_pcie_rscc_xo_clk_src.clkr, 7151 [GCC_PCIE_THROTTLE_CFG_CLK] = &gcc_pcie_throttle_cfg_clk.clkr, 7152 [GCC_PDM2_CLK] = &gcc_pdm2_clk.clkr, 7153 [GCC_PDM2_CLK_SRC] = &gcc_pdm2_clk_src.clkr, 7154 [GCC_PDM_AHB_CLK] = &gcc_pdm_ahb_clk.clkr, 7155 [GCC_PDM_XO4_CLK] = &gcc_pdm_xo4_clk.clkr, 7156 [GCC_QMIP_CAMERA_NRT_AHB_CLK] = &gcc_qmip_camera_nrt_ahb_clk.clkr, 7157 [GCC_QMIP_CAMERA_RT_AHB_CLK] = &gcc_qmip_camera_rt_ahb_clk.clkr, 7158 [GCC_QMIP_DISP1_AHB_CLK] = &gcc_qmip_disp1_ahb_clk.clkr, 7159 [GCC_QMIP_DISP1_ROT_AHB_CLK] = &gcc_qmip_disp1_rot_ahb_clk.clkr, 7160 [GCC_QMIP_DISP_AHB_CLK] = &gcc_qmip_disp_ahb_clk.clkr, 7161 [GCC_QMIP_DISP_ROT_AHB_CLK] = &gcc_qmip_disp_rot_ahb_clk.clkr, 7162 [GCC_QMIP_VIDEO_CVP_AHB_CLK] = &gcc_qmip_video_cvp_ahb_clk.clkr, 7163 [GCC_QMIP_VIDEO_VCODEC_AHB_CLK] = &gcc_qmip_video_vcodec_ahb_clk.clkr, 7164 [GCC_QUPV3_WRAP0_CORE_2X_CLK] = &gcc_qupv3_wrap0_core_2x_clk.clkr, 7165 [GCC_QUPV3_WRAP0_CORE_CLK] = &gcc_qupv3_wrap0_core_clk.clkr, 7166 [GCC_QUPV3_WRAP0_QSPI0_CLK] = &gcc_qupv3_wrap0_qspi0_clk.clkr, 7167 [GCC_QUPV3_WRAP0_S0_CLK] = &gcc_qupv3_wrap0_s0_clk.clkr, 7168 [GCC_QUPV3_WRAP0_S0_CLK_SRC] = &gcc_qupv3_wrap0_s0_clk_src.clkr, 7169 [GCC_QUPV3_WRAP0_S1_CLK] = &gcc_qupv3_wrap0_s1_clk.clkr, 7170 [GCC_QUPV3_WRAP0_S1_CLK_SRC] = &gcc_qupv3_wrap0_s1_clk_src.clkr, 7171 [GCC_QUPV3_WRAP0_S2_CLK] = &gcc_qupv3_wrap0_s2_clk.clkr, 7172 [GCC_QUPV3_WRAP0_S2_CLK_SRC] = &gcc_qupv3_wrap0_s2_clk_src.clkr, 7173 [GCC_QUPV3_WRAP0_S3_CLK] = &gcc_qupv3_wrap0_s3_clk.clkr, 7174 [GCC_QUPV3_WRAP0_S3_CLK_SRC] = &gcc_qupv3_wrap0_s3_clk_src.clkr, 7175 [GCC_QUPV3_WRAP0_S4_CLK] = &gcc_qupv3_wrap0_s4_clk.clkr, 7176 [GCC_QUPV3_WRAP0_S4_CLK_SRC] = &gcc_qupv3_wrap0_s4_clk_src.clkr, 7177 [GCC_QUPV3_WRAP0_S4_DIV_CLK_SRC] = &gcc_qupv3_wrap0_s4_div_clk_src.clkr, 7178 [GCC_QUPV3_WRAP0_S5_CLK] = &gcc_qupv3_wrap0_s5_clk.clkr, 7179 [GCC_QUPV3_WRAP0_S5_CLK_SRC] = &gcc_qupv3_wrap0_s5_clk_src.clkr, 7180 [GCC_QUPV3_WRAP0_S6_CLK] = &gcc_qupv3_wrap0_s6_clk.clkr, 7181 [GCC_QUPV3_WRAP0_S6_CLK_SRC] = &gcc_qupv3_wrap0_s6_clk_src.clkr, 7182 [GCC_QUPV3_WRAP0_S7_CLK] = &gcc_qupv3_wrap0_s7_clk.clkr, 7183 [GCC_QUPV3_WRAP0_S7_CLK_SRC] = &gcc_qupv3_wrap0_s7_clk_src.clkr, 7184 [GCC_QUPV3_WRAP1_CORE_2X_CLK] = &gcc_qupv3_wrap1_core_2x_clk.clkr, 7185 [GCC_QUPV3_WRAP1_CORE_CLK] = &gcc_qupv3_wrap1_core_clk.clkr, 7186 [GCC_QUPV3_WRAP1_QSPI0_CLK] = &gcc_qupv3_wrap1_qspi0_clk.clkr, 7187 [GCC_QUPV3_WRAP1_S0_CLK] = &gcc_qupv3_wrap1_s0_clk.clkr, 7188 [GCC_QUPV3_WRAP1_S0_CLK_SRC] = &gcc_qupv3_wrap1_s0_clk_src.clkr, 7189 [GCC_QUPV3_WRAP1_S1_CLK] = &gcc_qupv3_wrap1_s1_clk.clkr, 7190 [GCC_QUPV3_WRAP1_S1_CLK_SRC] = &gcc_qupv3_wrap1_s1_clk_src.clkr, 7191 [GCC_QUPV3_WRAP1_S2_CLK] = &gcc_qupv3_wrap1_s2_clk.clkr, 7192 [GCC_QUPV3_WRAP1_S2_CLK_SRC] = &gcc_qupv3_wrap1_s2_clk_src.clkr, 7193 [GCC_QUPV3_WRAP1_S3_CLK] = &gcc_qupv3_wrap1_s3_clk.clkr, 7194 [GCC_QUPV3_WRAP1_S3_CLK_SRC] = &gcc_qupv3_wrap1_s3_clk_src.clkr, 7195 [GCC_QUPV3_WRAP1_S4_CLK] = &gcc_qupv3_wrap1_s4_clk.clkr, 7196 [GCC_QUPV3_WRAP1_S4_CLK_SRC] = &gcc_qupv3_wrap1_s4_clk_src.clkr, 7197 [GCC_QUPV3_WRAP1_S4_DIV_CLK_SRC] = &gcc_qupv3_wrap1_s4_div_clk_src.clkr, 7198 [GCC_QUPV3_WRAP1_S5_CLK] = &gcc_qupv3_wrap1_s5_clk.clkr, 7199 [GCC_QUPV3_WRAP1_S5_CLK_SRC] = &gcc_qupv3_wrap1_s5_clk_src.clkr, 7200 [GCC_QUPV3_WRAP1_S6_CLK] = &gcc_qupv3_wrap1_s6_clk.clkr, 7201 [GCC_QUPV3_WRAP1_S6_CLK_SRC] = &gcc_qupv3_wrap1_s6_clk_src.clkr, 7202 [GCC_QUPV3_WRAP1_S7_CLK] = &gcc_qupv3_wrap1_s7_clk.clkr, 7203 [GCC_QUPV3_WRAP1_S7_CLK_SRC] = &gcc_qupv3_wrap1_s7_clk_src.clkr, 7204 [GCC_QUPV3_WRAP2_CORE_2X_CLK] = &gcc_qupv3_wrap2_core_2x_clk.clkr, 7205 [GCC_QUPV3_WRAP2_CORE_CLK] = &gcc_qupv3_wrap2_core_clk.clkr, 7206 [GCC_QUPV3_WRAP2_QSPI0_CLK] = &gcc_qupv3_wrap2_qspi0_clk.clkr, 7207 [GCC_QUPV3_WRAP2_S0_CLK] = &gcc_qupv3_wrap2_s0_clk.clkr, 7208 [GCC_QUPV3_WRAP2_S0_CLK_SRC] = &gcc_qupv3_wrap2_s0_clk_src.clkr, 7209 [GCC_QUPV3_WRAP2_S1_CLK] = &gcc_qupv3_wrap2_s1_clk.clkr, 7210 [GCC_QUPV3_WRAP2_S1_CLK_SRC] = &gcc_qupv3_wrap2_s1_clk_src.clkr, 7211 [GCC_QUPV3_WRAP2_S2_CLK] = &gcc_qupv3_wrap2_s2_clk.clkr, 7212 [GCC_QUPV3_WRAP2_S2_CLK_SRC] = &gcc_qupv3_wrap2_s2_clk_src.clkr, 7213 [GCC_QUPV3_WRAP2_S3_CLK] = &gcc_qupv3_wrap2_s3_clk.clkr, 7214 [GCC_QUPV3_WRAP2_S3_CLK_SRC] = &gcc_qupv3_wrap2_s3_clk_src.clkr, 7215 [GCC_QUPV3_WRAP2_S4_CLK] = &gcc_qupv3_wrap2_s4_clk.clkr, 7216 [GCC_QUPV3_WRAP2_S4_CLK_SRC] = &gcc_qupv3_wrap2_s4_clk_src.clkr, 7217 [GCC_QUPV3_WRAP2_S4_DIV_CLK_SRC] = &gcc_qupv3_wrap2_s4_div_clk_src.clkr, 7218 [GCC_QUPV3_WRAP2_S5_CLK] = &gcc_qupv3_wrap2_s5_clk.clkr, 7219 [GCC_QUPV3_WRAP2_S5_CLK_SRC] = &gcc_qupv3_wrap2_s5_clk_src.clkr, 7220 [GCC_QUPV3_WRAP2_S6_CLK] = &gcc_qupv3_wrap2_s6_clk.clkr, 7221 [GCC_QUPV3_WRAP2_S6_CLK_SRC] = &gcc_qupv3_wrap2_s6_clk_src.clkr, 7222 [GCC_QUPV3_WRAP2_S7_CLK] = &gcc_qupv3_wrap2_s7_clk.clkr, 7223 [GCC_QUPV3_WRAP2_S7_CLK_SRC] = &gcc_qupv3_wrap2_s7_clk_src.clkr, 7224 [GCC_QUPV3_WRAP_0_M_AHB_CLK] = &gcc_qupv3_wrap_0_m_ahb_clk.clkr, 7225 [GCC_QUPV3_WRAP_0_S_AHB_CLK] = &gcc_qupv3_wrap_0_s_ahb_clk.clkr, 7226 [GCC_QUPV3_WRAP_1_M_AHB_CLK] = &gcc_qupv3_wrap_1_m_ahb_clk.clkr, 7227 [GCC_QUPV3_WRAP_1_S_AHB_CLK] = &gcc_qupv3_wrap_1_s_ahb_clk.clkr, 7228 [GCC_QUPV3_WRAP_2_M_AHB_CLK] = &gcc_qupv3_wrap_2_m_ahb_clk.clkr, 7229 [GCC_QUPV3_WRAP_2_S_AHB_CLK] = &gcc_qupv3_wrap_2_s_ahb_clk.clkr, 7230 [GCC_SDCC2_AHB_CLK] = &gcc_sdcc2_ahb_clk.clkr, 7231 [GCC_SDCC2_APPS_CLK] = &gcc_sdcc2_apps_clk.clkr, 7232 [GCC_SDCC2_APPS_CLK_SRC] = &gcc_sdcc2_apps_clk_src.clkr, 7233 [GCC_SDCC4_AHB_CLK] = &gcc_sdcc4_ahb_clk.clkr, 7234 [GCC_SDCC4_APPS_CLK] = &gcc_sdcc4_apps_clk.clkr, 7235 [GCC_SDCC4_APPS_CLK_SRC] = &gcc_sdcc4_apps_clk_src.clkr, 7236 [GCC_SYS_NOC_USB_AXI_CLK] = &gcc_sys_noc_usb_axi_clk.clkr, 7237 [GCC_UFS_1_CARD_CLKREF_CLK] = &gcc_ufs_1_card_clkref_clk.clkr, 7238 [GCC_UFS_CARD_AHB_CLK] = &gcc_ufs_card_ahb_clk.clkr, 7239 [GCC_UFS_CARD_AXI_CLK] = &gcc_ufs_card_axi_clk.clkr, 7240 [GCC_UFS_CARD_AXI_CLK_SRC] = &gcc_ufs_card_axi_clk_src.clkr, 7241 [GCC_UFS_CARD_AXI_HW_CTL_CLK] = &gcc_ufs_card_axi_hw_ctl_clk.clkr, 7242 [GCC_UFS_CARD_CLKREF_CLK] = &gcc_ufs_card_clkref_clk.clkr, 7243 [GCC_UFS_CARD_ICE_CORE_CLK] = &gcc_ufs_card_ice_core_clk.clkr, 7244 [GCC_UFS_CARD_ICE_CORE_CLK_SRC] = &gcc_ufs_card_ice_core_clk_src.clkr, 7245 [GCC_UFS_CARD_ICE_CORE_HW_CTL_CLK] = &gcc_ufs_card_ice_core_hw_ctl_clk.clkr, 7246 [GCC_UFS_CARD_PHY_AUX_CLK] = &gcc_ufs_card_phy_aux_clk.clkr, 7247 [GCC_UFS_CARD_PHY_AUX_CLK_SRC] = &gcc_ufs_card_phy_aux_clk_src.clkr, 7248 [GCC_UFS_CARD_PHY_AUX_HW_CTL_CLK] = &gcc_ufs_card_phy_aux_hw_ctl_clk.clkr, 7249 [GCC_UFS_CARD_RX_SYMBOL_0_CLK] = &gcc_ufs_card_rx_symbol_0_clk.clkr, 7250 [GCC_UFS_CARD_RX_SYMBOL_0_CLK_SRC] = &gcc_ufs_card_rx_symbol_0_clk_src.clkr, 7251 [GCC_UFS_CARD_RX_SYMBOL_1_CLK] = &gcc_ufs_card_rx_symbol_1_clk.clkr, 7252 [GCC_UFS_CARD_RX_SYMBOL_1_CLK_SRC] = &gcc_ufs_card_rx_symbol_1_clk_src.clkr, 7253 [GCC_UFS_CARD_TX_SYMBOL_0_CLK] = &gcc_ufs_card_tx_symbol_0_clk.clkr, 7254 [GCC_UFS_CARD_TX_SYMBOL_0_CLK_SRC] = &gcc_ufs_card_tx_symbol_0_clk_src.clkr, 7255 [GCC_UFS_CARD_UNIPRO_CORE_CLK] = &gcc_ufs_card_unipro_core_clk.clkr, 7256 [GCC_UFS_CARD_UNIPRO_CORE_CLK_SRC] = &gcc_ufs_card_unipro_core_clk_src.clkr, 7257 [GCC_UFS_CARD_UNIPRO_CORE_HW_CTL_CLK] = &gcc_ufs_card_unipro_core_hw_ctl_clk.clkr, 7258 [GCC_UFS_PHY_AHB_CLK] = &gcc_ufs_phy_ahb_clk.clkr, 7259 [GCC_UFS_PHY_AXI_CLK] = &gcc_ufs_phy_axi_clk.clkr, 7260 [GCC_UFS_PHY_AXI_CLK_SRC] = &gcc_ufs_phy_axi_clk_src.clkr, 7261 [GCC_UFS_PHY_AXI_HW_CTL_CLK] = &gcc_ufs_phy_axi_hw_ctl_clk.clkr, 7262 [GCC_UFS_PHY_ICE_CORE_CLK] = &gcc_ufs_phy_ice_core_clk.clkr, 7263 [GCC_UFS_PHY_ICE_CORE_CLK_SRC] = &gcc_ufs_phy_ice_core_clk_src.clkr, 7264 [GCC_UFS_PHY_ICE_CORE_HW_CTL_CLK] = &gcc_ufs_phy_ice_core_hw_ctl_clk.clkr, 7265 [GCC_UFS_PHY_PHY_AUX_CLK] = &gcc_ufs_phy_phy_aux_clk.clkr, 7266 [GCC_UFS_PHY_PHY_AUX_CLK_SRC] = &gcc_ufs_phy_phy_aux_clk_src.clkr, 7267 [GCC_UFS_PHY_PHY_AUX_HW_CTL_CLK] = &gcc_ufs_phy_phy_aux_hw_ctl_clk.clkr, 7268 [GCC_UFS_PHY_RX_SYMBOL_0_CLK] = &gcc_ufs_phy_rx_symbol_0_clk.clkr, 7269 [GCC_UFS_PHY_RX_SYMBOL_0_CLK_SRC] = &gcc_ufs_phy_rx_symbol_0_clk_src.clkr, 7270 [GCC_UFS_PHY_RX_SYMBOL_1_CLK] = &gcc_ufs_phy_rx_symbol_1_clk.clkr, 7271 [GCC_UFS_PHY_RX_SYMBOL_1_CLK_SRC] = &gcc_ufs_phy_rx_symbol_1_clk_src.clkr, 7272 [GCC_UFS_PHY_TX_SYMBOL_0_CLK] = &gcc_ufs_phy_tx_symbol_0_clk.clkr, 7273 [GCC_UFS_PHY_TX_SYMBOL_0_CLK_SRC] = &gcc_ufs_phy_tx_symbol_0_clk_src.clkr, 7274 [GCC_UFS_PHY_UNIPRO_CORE_CLK] = &gcc_ufs_phy_unipro_core_clk.clkr, 7275 [GCC_UFS_PHY_UNIPRO_CORE_CLK_SRC] = &gcc_ufs_phy_unipro_core_clk_src.clkr, 7276 [GCC_UFS_PHY_UNIPRO_CORE_HW_CTL_CLK] = &gcc_ufs_phy_unipro_core_hw_ctl_clk.clkr, 7277 [GCC_UFS_REF_CLKREF_CLK] = &gcc_ufs_ref_clkref_clk.clkr, 7278 [GCC_USB2_HS0_CLKREF_CLK] = &gcc_usb2_hs0_clkref_clk.clkr, 7279 [GCC_USB2_HS1_CLKREF_CLK] = &gcc_usb2_hs1_clkref_clk.clkr, 7280 [GCC_USB2_HS2_CLKREF_CLK] = &gcc_usb2_hs2_clkref_clk.clkr, 7281 [GCC_USB2_HS3_CLKREF_CLK] = &gcc_usb2_hs3_clkref_clk.clkr, 7282 [GCC_USB30_MP_MASTER_CLK] = &gcc_usb30_mp_master_clk.clkr, 7283 [GCC_USB30_MP_MASTER_CLK_SRC] = &gcc_usb30_mp_master_clk_src.clkr, 7284 [GCC_USB30_MP_MOCK_UTMI_CLK] = &gcc_usb30_mp_mock_utmi_clk.clkr, 7285 [GCC_USB30_MP_MOCK_UTMI_CLK_SRC] = &gcc_usb30_mp_mock_utmi_clk_src.clkr, 7286 [GCC_USB30_MP_MOCK_UTMI_POSTDIV_CLK_SRC] = &gcc_usb30_mp_mock_utmi_postdiv_clk_src.clkr, 7287 [GCC_USB30_MP_SLEEP_CLK] = &gcc_usb30_mp_sleep_clk.clkr, 7288 [GCC_USB30_PRIM_MASTER_CLK] = &gcc_usb30_prim_master_clk.clkr, 7289 [GCC_USB30_PRIM_MASTER_CLK_SRC] = &gcc_usb30_prim_master_clk_src.clkr, 7290 [GCC_USB30_PRIM_MOCK_UTMI_CLK] = &gcc_usb30_prim_mock_utmi_clk.clkr, 7291 [GCC_USB30_PRIM_MOCK_UTMI_CLK_SRC] = &gcc_usb30_prim_mock_utmi_clk_src.clkr, 7292 [GCC_USB30_PRIM_MOCK_UTMI_POSTDIV_CLK_SRC] = &gcc_usb30_prim_mock_utmi_postdiv_clk_src.clkr, 7293 [GCC_USB30_PRIM_SLEEP_CLK] = &gcc_usb30_prim_sleep_clk.clkr, 7294 [GCC_USB30_SEC_MASTER_CLK] = &gcc_usb30_sec_master_clk.clkr, 7295 [GCC_USB30_SEC_MASTER_CLK_SRC] = &gcc_usb30_sec_master_clk_src.clkr, 7296 [GCC_USB30_SEC_MOCK_UTMI_CLK] = &gcc_usb30_sec_mock_utmi_clk.clkr, 7297 [GCC_USB30_SEC_MOCK_UTMI_CLK_SRC] = &gcc_usb30_sec_mock_utmi_clk_src.clkr, 7298 [GCC_USB30_SEC_MOCK_UTMI_POSTDIV_CLK_SRC] = &gcc_usb30_sec_mock_utmi_postdiv_clk_src.clkr, 7299 [GCC_USB30_SEC_SLEEP_CLK] = &gcc_usb30_sec_sleep_clk.clkr, 7300 [GCC_USB34_PRIM_PHY_PIPE_CLK_SRC] = &gcc_usb34_prim_phy_pipe_clk_src.clkr, 7301 [GCC_USB34_SEC_PHY_PIPE_CLK_SRC] = &gcc_usb34_sec_phy_pipe_clk_src.clkr, 7302 [GCC_USB3_MP0_CLKREF_CLK] = &gcc_usb3_mp0_clkref_clk.clkr, 7303 [GCC_USB3_MP1_CLKREF_CLK] = &gcc_usb3_mp1_clkref_clk.clkr, 7304 [GCC_USB3_MP_PHY_AUX_CLK] = &gcc_usb3_mp_phy_aux_clk.clkr, 7305 [GCC_USB3_MP_PHY_AUX_CLK_SRC] = &gcc_usb3_mp_phy_aux_clk_src.clkr, 7306 [GCC_USB3_MP_PHY_COM_AUX_CLK] = &gcc_usb3_mp_phy_com_aux_clk.clkr, 7307 [GCC_USB3_MP_PHY_PIPE_0_CLK] = &gcc_usb3_mp_phy_pipe_0_clk.clkr, 7308 [GCC_USB3_MP_PHY_PIPE_0_CLK_SRC] = &gcc_usb3_mp_phy_pipe_0_clk_src.clkr, 7309 [GCC_USB3_MP_PHY_PIPE_1_CLK] = &gcc_usb3_mp_phy_pipe_1_clk.clkr, 7310 [GCC_USB3_MP_PHY_PIPE_1_CLK_SRC] = &gcc_usb3_mp_phy_pipe_1_clk_src.clkr, 7311 [GCC_USB3_PRIM_PHY_AUX_CLK] = &gcc_usb3_prim_phy_aux_clk.clkr, 7312 [GCC_USB3_PRIM_PHY_AUX_CLK_SRC] = &gcc_usb3_prim_phy_aux_clk_src.clkr, 7313 [GCC_USB3_PRIM_PHY_COM_AUX_CLK] = &gcc_usb3_prim_phy_com_aux_clk.clkr, 7314 [GCC_USB3_PRIM_PHY_PIPE_CLK] = &gcc_usb3_prim_phy_pipe_clk.clkr, 7315 [GCC_USB3_PRIM_PHY_PIPE_CLK_SRC] = &gcc_usb3_prim_phy_pipe_clk_src.clkr, 7316 [GCC_USB3_SEC_PHY_AUX_CLK] = &gcc_usb3_sec_phy_aux_clk.clkr, 7317 [GCC_USB3_SEC_PHY_AUX_CLK_SRC] = &gcc_usb3_sec_phy_aux_clk_src.clkr, 7318 [GCC_USB3_SEC_PHY_COM_AUX_CLK] = &gcc_usb3_sec_phy_com_aux_clk.clkr, 7319 [GCC_USB3_SEC_PHY_PIPE_CLK] = &gcc_usb3_sec_phy_pipe_clk.clkr, 7320 [GCC_USB3_SEC_PHY_PIPE_CLK_SRC] = &gcc_usb3_sec_phy_pipe_clk_src.clkr, 7321 [GCC_USB4_1_CFG_AHB_CLK] = &gcc_usb4_1_cfg_ahb_clk.clkr, 7322 [GCC_USB4_1_DP_CLK] = &gcc_usb4_1_dp_clk.clkr, 7323 [GCC_USB4_1_MASTER_CLK] = &gcc_usb4_1_master_clk.clkr, 7324 [GCC_USB4_1_MASTER_CLK_SRC] = &gcc_usb4_1_master_clk_src.clkr, 7325 [GCC_USB4_1_PHY_DP_CLK_SRC] = &gcc_usb4_1_phy_dp_clk_src.clkr, 7326 [GCC_USB4_1_PHY_P2RR2P_PIPE_CLK] = &gcc_usb4_1_phy_p2rr2p_pipe_clk.clkr, 7327 [GCC_USB4_1_PHY_P2RR2P_PIPE_CLK_SRC] = &gcc_usb4_1_phy_p2rr2p_pipe_clk_src.clkr, 7328 [GCC_USB4_1_PHY_PCIE_PIPE_CLK] = &gcc_usb4_1_phy_pcie_pipe_clk.clkr, 7329 [GCC_USB4_1_PHY_PCIE_PIPE_CLK_SRC] = &gcc_usb4_1_phy_pcie_pipe_clk_src.clkr, 7330 [GCC_USB4_1_PHY_PCIE_PIPE_MUX_CLK_SRC] = &gcc_usb4_1_phy_pcie_pipe_mux_clk_src.clkr, 7331 [GCC_USB4_1_PHY_PCIE_PIPEGMUX_CLK_SRC] = &gcc_usb4_1_phy_pcie_pipegmux_clk_src.clkr, 7332 [GCC_USB4_1_PHY_RX0_CLK] = &gcc_usb4_1_phy_rx0_clk.clkr, 7333 [GCC_USB4_1_PHY_RX0_CLK_SRC] = &gcc_usb4_1_phy_rx0_clk_src.clkr, 7334 [GCC_USB4_1_PHY_RX1_CLK] = &gcc_usb4_1_phy_rx1_clk.clkr, 7335 [GCC_USB4_1_PHY_RX1_CLK_SRC] = &gcc_usb4_1_phy_rx1_clk_src.clkr, 7336 [GCC_USB4_1_PHY_SYS_CLK_SRC] = &gcc_usb4_1_phy_sys_clk_src.clkr, 7337 [GCC_USB4_1_PHY_USB_PIPE_CLK] = &gcc_usb4_1_phy_usb_pipe_clk.clkr, 7338 [GCC_USB4_1_SB_IF_CLK] = &gcc_usb4_1_sb_if_clk.clkr, 7339 [GCC_USB4_1_SB_IF_CLK_SRC] = &gcc_usb4_1_sb_if_clk_src.clkr, 7340 [GCC_USB4_1_SYS_CLK] = &gcc_usb4_1_sys_clk.clkr, 7341 [GCC_USB4_1_TMU_CLK] = &gcc_usb4_1_tmu_clk.clkr, 7342 [GCC_USB4_1_TMU_CLK_SRC] = &gcc_usb4_1_tmu_clk_src.clkr, 7343 [GCC_USB4_CFG_AHB_CLK] = &gcc_usb4_cfg_ahb_clk.clkr, 7344 [GCC_USB4_CLKREF_CLK] = &gcc_usb4_clkref_clk.clkr, 7345 [GCC_USB4_DP_CLK] = &gcc_usb4_dp_clk.clkr, 7346 [GCC_USB4_EUD_CLKREF_CLK] = &gcc_usb4_eud_clkref_clk.clkr, 7347 [GCC_USB4_MASTER_CLK] = &gcc_usb4_master_clk.clkr, 7348 [GCC_USB4_MASTER_CLK_SRC] = &gcc_usb4_master_clk_src.clkr, 7349 [GCC_USB4_PHY_DP_CLK_SRC] = &gcc_usb4_phy_dp_clk_src.clkr, 7350 [GCC_USB4_PHY_P2RR2P_PIPE_CLK] = &gcc_usb4_phy_p2rr2p_pipe_clk.clkr, 7351 [GCC_USB4_PHY_P2RR2P_PIPE_CLK_SRC] = &gcc_usb4_phy_p2rr2p_pipe_clk_src.clkr, 7352 [GCC_USB4_PHY_PCIE_PIPE_CLK] = &gcc_usb4_phy_pcie_pipe_clk.clkr, 7353 [GCC_USB4_PHY_PCIE_PIPE_CLK_SRC] = &gcc_usb4_phy_pcie_pipe_clk_src.clkr, 7354 [GCC_USB4_PHY_PCIE_PIPE_MUX_CLK_SRC] = &gcc_usb4_phy_pcie_pipe_mux_clk_src.clkr, 7355 [GCC_USB4_PHY_PCIE_PIPEGMUX_CLK_SRC] = &gcc_usb4_phy_pcie_pipegmux_clk_src.clkr, 7356 [GCC_USB4_PHY_RX0_CLK] = &gcc_usb4_phy_rx0_clk.clkr, 7357 [GCC_USB4_PHY_RX0_CLK_SRC] = &gcc_usb4_phy_rx0_clk_src.clkr, 7358 [GCC_USB4_PHY_RX1_CLK] = &gcc_usb4_phy_rx1_clk.clkr, 7359 [GCC_USB4_PHY_RX1_CLK_SRC] = &gcc_usb4_phy_rx1_clk_src.clkr, 7360 [GCC_USB4_PHY_SYS_CLK_SRC] = &gcc_usb4_phy_sys_clk_src.clkr, 7361 [GCC_USB4_PHY_USB_PIPE_CLK] = &gcc_usb4_phy_usb_pipe_clk.clkr, 7362 [GCC_USB4_SB_IF_CLK] = &gcc_usb4_sb_if_clk.clkr, 7363 [GCC_USB4_SB_IF_CLK_SRC] = &gcc_usb4_sb_if_clk_src.clkr, 7364 [GCC_USB4_SYS_CLK] = &gcc_usb4_sys_clk.clkr, 7365 [GCC_USB4_TMU_CLK] = &gcc_usb4_tmu_clk.clkr, 7366 [GCC_USB4_TMU_CLK_SRC] = &gcc_usb4_tmu_clk_src.clkr, 7367 [GCC_VIDEO_AXI0_CLK] = &gcc_video_axi0_clk.clkr, 7368 [GCC_VIDEO_AXI1_CLK] = &gcc_video_axi1_clk.clkr, 7369 [GCC_VIDEO_CVP_THROTTLE_CLK] = &gcc_video_cvp_throttle_clk.clkr, 7370 [GCC_VIDEO_VCODEC_THROTTLE_CLK] = &gcc_video_vcodec_throttle_clk.clkr, 7371 }; 7372 7373 static const struct qcom_reset_map gcc_sc8280xp_resets[] = { 7374 [GCC_EMAC0_BCR] = { 0xaa000 }, 7375 [GCC_EMAC1_BCR] = { 0xba000 }, 7376 [GCC_PCIE_0_LINK_DOWN_BCR] = { 0x6c014 }, 7377 [GCC_PCIE_0_NOCSR_COM_PHY_BCR] = { 0x6c020 }, 7378 [GCC_PCIE_0_PHY_BCR] = { 0x6c01c }, 7379 [GCC_PCIE_0_PHY_NOCSR_COM_PHY_BCR] = { 0x6c028 }, 7380 [GCC_PCIE_0_TUNNEL_BCR] = { 0xa4000 }, 7381 [GCC_PCIE_1_LINK_DOWN_BCR] = { 0x8e014 }, 7382 [GCC_PCIE_1_NOCSR_COM_PHY_BCR] = { 0x8e020 }, 7383 [GCC_PCIE_1_PHY_BCR] = { 0x8e01c }, 7384 [GCC_PCIE_1_PHY_NOCSR_COM_PHY_BCR] = { 0x8e000 }, 7385 [GCC_PCIE_1_TUNNEL_BCR] = { 0x8d000 }, 7386 [GCC_PCIE_2A_BCR] = { 0x9d000 }, 7387 [GCC_PCIE_2A_LINK_DOWN_BCR] = { 0x9d13c }, 7388 [GCC_PCIE_2A_NOCSR_COM_PHY_BCR] = { 0x9d148 }, 7389 [GCC_PCIE_2A_PHY_BCR] = { 0x9d144 }, 7390 [GCC_PCIE_2A_PHY_NOCSR_COM_PHY_BCR] = { 0x9d14c }, 7391 [GCC_PCIE_2B_BCR] = { 0x9e000 }, 7392 [GCC_PCIE_2B_LINK_DOWN_BCR] = { 0x9e084 }, 7393 [GCC_PCIE_2B_NOCSR_COM_PHY_BCR] = { 0x9e090 }, 7394 [GCC_PCIE_2B_PHY_BCR] = { 0x9e08c }, 7395 [GCC_PCIE_2B_PHY_NOCSR_COM_PHY_BCR] = { 0x9e094 }, 7396 [GCC_PCIE_3A_BCR] = { 0xa0000 }, 7397 [GCC_PCIE_3A_LINK_DOWN_BCR] = { 0xa00f0 }, 7398 [GCC_PCIE_3A_NOCSR_COM_PHY_BCR] = { 0xa00fc }, 7399 [GCC_PCIE_3A_PHY_BCR] = { 0xa00e0 }, 7400 [GCC_PCIE_3A_PHY_NOCSR_COM_PHY_BCR] = { 0xa00e4 }, 7401 [GCC_PCIE_3B_BCR] = { 0xa2000 }, 7402 [GCC_PCIE_3B_LINK_DOWN_BCR] = { 0xa20e0 }, 7403 [GCC_PCIE_3B_NOCSR_COM_PHY_BCR] = { 0xa20ec }, 7404 [GCC_PCIE_3B_PHY_BCR] = { 0xa20e8 }, 7405 [GCC_PCIE_3B_PHY_NOCSR_COM_PHY_BCR] = { 0xa20f0 }, 7406 [GCC_PCIE_4_BCR] = { 0x6b000 }, 7407 [GCC_PCIE_4_LINK_DOWN_BCR] = { 0x6b300 }, 7408 [GCC_PCIE_4_NOCSR_COM_PHY_BCR] = { 0x6b30c }, 7409 [GCC_PCIE_4_PHY_BCR] = { 0x6b308 }, 7410 [GCC_PCIE_4_PHY_NOCSR_COM_PHY_BCR] = { 0x6b310 }, 7411 [GCC_PCIE_PHY_CFG_AHB_BCR] = { 0x6f00c }, 7412 [GCC_PCIE_PHY_COM_BCR] = { 0x6f010 }, 7413 [GCC_PCIE_RSCC_BCR] = { 0xae000 }, 7414 [GCC_QUSB2PHY_HS0_MP_BCR] = { 0x12008 }, 7415 [GCC_QUSB2PHY_HS1_MP_BCR] = { 0x1200c }, 7416 [GCC_QUSB2PHY_HS2_MP_BCR] = { 0x12010 }, 7417 [GCC_QUSB2PHY_HS3_MP_BCR] = { 0x12014 }, 7418 [GCC_QUSB2PHY_PRIM_BCR] = { 0x12000 }, 7419 [GCC_QUSB2PHY_SEC_BCR] = { 0x12004 }, 7420 [GCC_SDCC2_BCR] = { 0x14000 }, 7421 [GCC_SDCC4_BCR] = { 0x16000 }, 7422 [GCC_UFS_CARD_BCR] = { 0x75000 }, 7423 [GCC_UFS_PHY_BCR] = { 0x77000 }, 7424 [GCC_USB2_PHY_PRIM_BCR] = { 0x50028 }, 7425 [GCC_USB2_PHY_SEC_BCR] = { 0x5002c }, 7426 [GCC_USB30_MP_BCR] = { 0xab000 }, 7427 [GCC_USB30_PRIM_BCR] = { 0xf000 }, 7428 [GCC_USB30_SEC_BCR] = { 0x10000 }, 7429 [GCC_USB3_DP_PHY_PRIM_BCR] = { 0x50008 }, 7430 [GCC_USB3_DP_PHY_SEC_BCR] = { 0x50014 }, 7431 [GCC_USB3_PHY_PRIM_BCR] = { 0x50000 }, 7432 [GCC_USB3_PHY_SEC_BCR] = { 0x5000c }, 7433 [GCC_USB3_UNIPHY_MP0_BCR] = { 0x50018 }, 7434 [GCC_USB3_UNIPHY_MP1_BCR] = { 0x5001c }, 7435 [GCC_USB3PHY_PHY_PRIM_BCR] = { 0x50004 }, 7436 [GCC_USB3PHY_PHY_SEC_BCR] = { 0x50010 }, 7437 [GCC_USB3UNIPHY_PHY_MP0_BCR] = { 0x50020 }, 7438 [GCC_USB3UNIPHY_PHY_MP1_BCR] = { 0x50024 }, 7439 [GCC_USB4_1_BCR] = { 0xb8000 }, 7440 [GCC_USB4_1_DP_PHY_PRIM_BCR] = { 0xb9020 }, 7441 [GCC_USB4_1_DPPHY_AUX_BCR] = { 0xb9024 }, 7442 [GCC_USB4_1_PHY_PRIM_BCR] = { 0xb9018 }, 7443 [GCC_USB4_BCR] = { 0x2a000 }, 7444 [GCC_USB4_DP_PHY_PRIM_BCR] = { 0x4a008 }, 7445 [GCC_USB4_DPPHY_AUX_BCR] = { 0x4a00c }, 7446 [GCC_USB4_PHY_PRIM_BCR] = { 0x4a000 }, 7447 [GCC_USB4PHY_1_PHY_PRIM_BCR] = { 0xb901c }, 7448 [GCC_USB4PHY_PHY_PRIM_BCR] = { 0x4a004 }, 7449 [GCC_USB_PHY_CFG_AHB2PHY_BCR] = { 0x6a000 }, 7450 [GCC_VIDEO_BCR] = { 0x28000 }, 7451 [GCC_VIDEO_AXI0_CLK_ARES] = { .reg = 0x28010, .bit = 2, .udelay = 400 }, 7452 [GCC_VIDEO_AXI1_CLK_ARES] = { .reg = 0x28018, .bit = 2, .udelay = 400 }, 7453 }; 7454 7455 static struct gdsc *gcc_sc8280xp_gdscs[] = { 7456 [PCIE_0_TUNNEL_GDSC] = &pcie_0_tunnel_gdsc, 7457 [PCIE_1_TUNNEL_GDSC] = &pcie_1_tunnel_gdsc, 7458 [PCIE_2A_GDSC] = &pcie_2a_gdsc, 7459 [PCIE_2B_GDSC] = &pcie_2b_gdsc, 7460 [PCIE_3A_GDSC] = &pcie_3a_gdsc, 7461 [PCIE_3B_GDSC] = &pcie_3b_gdsc, 7462 [PCIE_4_GDSC] = &pcie_4_gdsc, 7463 [UFS_CARD_GDSC] = &ufs_card_gdsc, 7464 [UFS_PHY_GDSC] = &ufs_phy_gdsc, 7465 [USB30_MP_GDSC] = &usb30_mp_gdsc, 7466 [USB30_PRIM_GDSC] = &usb30_prim_gdsc, 7467 [USB30_SEC_GDSC] = &usb30_sec_gdsc, 7468 [EMAC_0_GDSC] = &emac_0_gdsc, 7469 [EMAC_1_GDSC] = &emac_1_gdsc, 7470 [USB4_1_GDSC] = &usb4_1_gdsc, 7471 [USB4_GDSC] = &usb4_gdsc, 7472 [HLOS1_VOTE_MMNOC_MMU_TBU_HF0_GDSC] = &hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc, 7473 [HLOS1_VOTE_MMNOC_MMU_TBU_HF1_GDSC] = &hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc, 7474 [HLOS1_VOTE_MMNOC_MMU_TBU_SF0_GDSC] = &hlos1_vote_mmnoc_mmu_tbu_sf0_gdsc, 7475 [HLOS1_VOTE_MMNOC_MMU_TBU_SF1_GDSC] = &hlos1_vote_mmnoc_mmu_tbu_sf1_gdsc, 7476 [HLOS1_VOTE_TURING_MMU_TBU0_GDSC] = &hlos1_vote_turing_mmu_tbu0_gdsc, 7477 [HLOS1_VOTE_TURING_MMU_TBU1_GDSC] = &hlos1_vote_turing_mmu_tbu1_gdsc, 7478 [HLOS1_VOTE_TURING_MMU_TBU2_GDSC] = &hlos1_vote_turing_mmu_tbu2_gdsc, 7479 [HLOS1_VOTE_TURING_MMU_TBU3_GDSC] = &hlos1_vote_turing_mmu_tbu3_gdsc, 7480 }; 7481 7482 static const struct clk_rcg_dfs_data gcc_dfs_clocks[] = { 7483 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s0_clk_src), 7484 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s1_clk_src), 7485 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s2_clk_src), 7486 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s3_clk_src), 7487 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s4_clk_src), 7488 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s5_clk_src), 7489 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s6_clk_src), 7490 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s7_clk_src), 7491 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s0_clk_src), 7492 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s1_clk_src), 7493 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s2_clk_src), 7494 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s3_clk_src), 7495 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s4_clk_src), 7496 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s5_clk_src), 7497 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s6_clk_src), 7498 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s7_clk_src), 7499 DEFINE_RCG_DFS(gcc_qupv3_wrap2_s0_clk_src), 7500 DEFINE_RCG_DFS(gcc_qupv3_wrap2_s1_clk_src), 7501 DEFINE_RCG_DFS(gcc_qupv3_wrap2_s2_clk_src), 7502 DEFINE_RCG_DFS(gcc_qupv3_wrap2_s3_clk_src), 7503 DEFINE_RCG_DFS(gcc_qupv3_wrap2_s4_clk_src), 7504 DEFINE_RCG_DFS(gcc_qupv3_wrap2_s5_clk_src), 7505 DEFINE_RCG_DFS(gcc_qupv3_wrap2_s6_clk_src), 7506 DEFINE_RCG_DFS(gcc_qupv3_wrap2_s7_clk_src), 7507 }; 7508 7509 static const struct regmap_config gcc_sc8280xp_regmap_config = { 7510 .reg_bits = 32, 7511 .reg_stride = 4, 7512 .val_bits = 32, 7513 .max_register = 0xc3014, 7514 .fast_io = true, 7515 }; 7516 7517 static const struct qcom_cc_desc gcc_sc8280xp_desc = { 7518 .config = &gcc_sc8280xp_regmap_config, 7519 .clks = gcc_sc8280xp_clocks, 7520 .num_clks = ARRAY_SIZE(gcc_sc8280xp_clocks), 7521 .resets = gcc_sc8280xp_resets, 7522 .num_resets = ARRAY_SIZE(gcc_sc8280xp_resets), 7523 .gdscs = gcc_sc8280xp_gdscs, 7524 .num_gdscs = ARRAY_SIZE(gcc_sc8280xp_gdscs), 7525 }; 7526 7527 static int gcc_sc8280xp_probe(struct platform_device *pdev) 7528 { 7529 struct regmap *regmap; 7530 int ret; 7531 7532 ret = devm_pm_runtime_enable(&pdev->dev); 7533 if (ret) 7534 return ret; 7535 7536 ret = pm_runtime_resume_and_get(&pdev->dev); 7537 if (ret) 7538 return ret; 7539 7540 regmap = qcom_cc_map(pdev, &gcc_sc8280xp_desc); 7541 if (IS_ERR(regmap)) { 7542 ret = PTR_ERR(regmap); 7543 goto err_put_rpm; 7544 } 7545 7546 /* Keep some clocks always-on */ 7547 qcom_branch_set_clk_en(regmap, 0x26004); /* GCC_CAMERA_AHB_CLK */ 7548 qcom_branch_set_clk_en(regmap, 0x26020); /* GCC_CAMERA_XO_CLK */ 7549 qcom_branch_set_clk_en(regmap, 0x27004); /* GCC_DISP_AHB_CLK */ 7550 qcom_branch_set_clk_en(regmap, 0x27028); /* GCC_DISP_XO_CLK */ 7551 qcom_branch_set_clk_en(regmap, 0x71004); /* GCC_GPU_CFG_AHB_CLK */ 7552 qcom_branch_set_clk_en(regmap, 0x28004); /* GCC_VIDEO_AHB_CLK */ 7553 qcom_branch_set_clk_en(regmap, 0x28028); /* GCC_VIDEO_XO_CLK */ 7554 qcom_branch_set_clk_en(regmap, 0xbb004); /* GCC_DISP1_AHB_CLK */ 7555 qcom_branch_set_clk_en(regmap, 0xbb028); /* GCC_DISP1_XO_CLK */ 7556 7557 ret = qcom_cc_register_rcg_dfs(regmap, gcc_dfs_clocks, ARRAY_SIZE(gcc_dfs_clocks)); 7558 if (ret) 7559 goto err_put_rpm; 7560 7561 ret = qcom_cc_really_probe(&pdev->dev, &gcc_sc8280xp_desc, regmap); 7562 if (ret) 7563 goto err_put_rpm; 7564 7565 pm_runtime_put(&pdev->dev); 7566 7567 return 0; 7568 7569 err_put_rpm: 7570 pm_runtime_put_sync(&pdev->dev); 7571 7572 return ret; 7573 } 7574 7575 static const struct of_device_id gcc_sc8280xp_match_table[] = { 7576 { .compatible = "qcom,gcc-sc8280xp" }, 7577 { } 7578 }; 7579 MODULE_DEVICE_TABLE(of, gcc_sc8280xp_match_table); 7580 7581 static struct platform_driver gcc_sc8280xp_driver = { 7582 .probe = gcc_sc8280xp_probe, 7583 .driver = { 7584 .name = "gcc-sc8280xp", 7585 .of_match_table = gcc_sc8280xp_match_table, 7586 }, 7587 }; 7588 7589 static int __init gcc_sc8280xp_init(void) 7590 { 7591 return platform_driver_register(&gcc_sc8280xp_driver); 7592 } 7593 subsys_initcall(gcc_sc8280xp_init); 7594 7595 static void __exit gcc_sc8280xp_exit(void) 7596 { 7597 platform_driver_unregister(&gcc_sc8280xp_driver); 7598 } 7599 module_exit(gcc_sc8280xp_exit); 7600 7601 MODULE_DESCRIPTION("Qualcomm SC8280XP GCC driver"); 7602 MODULE_LICENSE("GPL"); 7603