Message ID | 20230124141541.8290-1-quic_devipriy@quicinc.com |
---|---|
Headers | show |
Series | Add minimal boot support for IPQ9574 | expand |
On 24/01/2023 15:15, devi priya wrote: > The IPQ9574 is Qualcomm's 802.11ax SoC for Routers, > Gateways and Access Points. > > This series adds minimal board boot support for ipq9574-al02-c7 board > > [V1] You already sent a v1. This should be v2. > Fixed all the review comments That's not specific enough. Best regards, Krzysztof
On 24/01/2023 15:15, devi priya wrote: > From: Poovendhan Selvaraj <quic_poovendh@quicinc.com> > > Add initial device tree support for Qualcomm IPQ9574 SoC > and AL02 board > > Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> > Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> > Co-developed-by: devi priya <quic_devipriy@quicinc.com> > Signed-off-by: devi priya <quic_devipriy@quicinc.com> > Signed-off-by: Poovendhan Selvaraj <quic_poovendh@quicinc.com> > --- > arch/arm64/boot/dts/qcom/Makefile | 1 + > arch/arm64/boot/dts/qcom/ipq9574-al02-c7.dts | 78 +++++ > arch/arm64/boot/dts/qcom/ipq9574.dtsi | 285 +++++++++++++++++++ > 3 files changed, 364 insertions(+) > create mode 100644 arch/arm64/boot/dts/qcom/ipq9574-al02-c7.dts > create mode 100644 arch/arm64/boot/dts/qcom/ipq9574.dtsi > > diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile > index 3e79496292e7..872c62028a0b 100644 > --- a/arch/arm64/boot/dts/qcom/Makefile > +++ b/arch/arm64/boot/dts/qcom/Makefile > @@ -7,6 +7,7 @@ dtb-$(CONFIG_ARCH_QCOM) += ipq6018-cp01-c1.dtb > dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk01.dtb > dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk10-c1.dtb > dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk10-c2.dtb > +dtb-$(CONFIG_ARCH_QCOM) += ipq9574-al02-c7.dtb > dtb-$(CONFIG_ARCH_QCOM) += msm8916-alcatel-idol347.dtb This does not match current tree, so I could not apply it for tests. I think you based it on a bit older version. Best regards, Krzysztof
On Tue, 24 Jan 2023 at 16:17, devi priya <quic_devipriy@quicinc.com> wrote: > > From: Poovendhan Selvaraj <quic_poovendh@quicinc.com> > > Add initial device tree support for Qualcomm IPQ9574 SoC > and AL02 board > > Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> > Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> > Co-developed-by: devi priya <quic_devipriy@quicinc.com> > Signed-off-by: devi priya <quic_devipriy@quicinc.com> > Signed-off-by: Poovendhan Selvaraj <quic_poovendh@quicinc.com> I suspect that the order of sign-offs is incorrect here. Your sign-off should be the last one, as you are the person sending the patch.
On 1/24/2023 7:45 PM, devi priya wrote: > Add clock and reset ID definitions for ipq9574 > > Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> > Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> > Signed-off-by: devi priya <quic_devipriy@quicinc.com> > --- > .../bindings/clock/qcom,gcc-other.yaml | 39 +++- > include/dt-bindings/clock/qcom,ipq9574-gcc.h | 213 ++++++++++++++++++ > include/dt-bindings/reset/qcom,ipq9574-gcc.h | 164 ++++++++++++++ > 3 files changed, 413 insertions(+), 3 deletions(-) > create mode 100644 include/dt-bindings/clock/qcom,ipq9574-gcc.h > create mode 100644 include/dt-bindings/reset/qcom,ipq9574-gcc.h > > diff --git a/Documentation/devicetree/bindings/clock/qcom,gcc-other.yaml b/Documentation/devicetree/bindings/clock/qcom,gcc-other.yaml > index 2e8acca64af1..b8de54b25c2a 100644 > --- a/Documentation/devicetree/bindings/clock/qcom,gcc-other.yaml > +++ b/Documentation/devicetree/bindings/clock/qcom,gcc-other.yaml > @@ -18,19 +18,19 @@ description: | > include/dt-bindings/clock/qcom,gcc-ipq4019.h > include/dt-bindings/clock/qcom,gcc-ipq6018.h > include/dt-bindings/reset/qcom,gcc-ipq6018.h > + include/dt-bindings/clock/qcom,ipq9574-gcc.h > + include/dt-bindings/reset/qcom,ipq9574-gcc.h > include/dt-bindings/clock/qcom,gcc-msm8953.h > include/dt-bindings/clock/qcom,gcc-mdm9607.h > include/dt-bindings/clock/qcom,gcc-mdm9615.h > include/dt-bindings/reset/qcom,gcc-mdm9615.h > > -allOf: > - - $ref: qcom,gcc.yaml# > - > properties: > compatible: > enum: > - qcom,gcc-ipq4019 > - qcom,gcc-ipq6018 > + - qcom,ipq9574-gcc > - qcom,gcc-mdm9607 > - qcom,gcc-msm8953 > - qcom,gcc-mdm9615 > @@ -38,6 +38,39 @@ properties: > required: > - compatible > > +allOf: > + - $ref: qcom,gcc.yaml# > + > + - if: > + properties: > + compatible: > + contains: > + enum: > + - qcom,ipq9574-gcc > + then: > + properties: > + clocks: > + items: > + - description: Board XO source > + - description: Sleep clock source > + - description: Bias PLL ubi clock source > + - description: PCIE30 PHY0 pipe clock source > + - description: PCIE30 PHY1 pipe clock source > + - description: PCIE30 PHY2 pipe clock source > + - description: PCIE30 PHY3 pipe clock source > + - description: USB3 PHY pipe clock source > + > + clock-names: > + items: > + - const: xo > + - const: sleep_clk > + - const: bias_pll_ubi_nc_clk > + - const: pcie30_phy0_pipe_clk > + - const: pcie30_phy1_pipe_clk > + - const: pcie30_phy2_pipe_clk > + - const: pcie30_phy3_pipe_clk > + - const: usb3phy_0_cc_pipe_clk How about creating a separate binding for IPQ9574 ? Looks like recently some bindings are separated out to individual files. > + > unevaluatedProperties: false > > examples: > diff --git a/include/dt-bindings/clock/qcom,ipq9574-gcc.h b/include/dt-bindings/clock/qcom,ipq9574-gcc.h > new file mode 100644 > index 000000000000..feedfdd5e00a > --- /dev/null > +++ b/include/dt-bindings/clock/qcom,ipq9574-gcc.h > @@ -0,0 +1,213 @@ > +/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) */ > +/* > + * Copyright (c) 2018-2023 The Linux Foundation. All rights reserved. > + */ > + > +#ifndef _DT_BINDINGS_CLOCK_IPQ_GCC_9048_H > +#define _DT_BINDINGS_CLOCK_IPQ_GCC_9048_H > + > +#define GPLL0_MAIN 0 > +#define GPLL0 1 > +#define GPLL2_MAIN 2 > +#define GPLL2 3 > +#define GPLL4_MAIN 4 > +#define GPLL4 5 > +#define GCC_SLEEP_CLK_SRC 6 > +#define APSS_AHB_CLK_SRC 7 > +#define APSS_AXI_CLK_SRC 8 > +#define BLSP1_QUP1_I2C_APPS_CLK_SRC 9 > +#define BLSP1_QUP1_SPI_APPS_CLK_SRC 10 > +#define BLSP1_QUP2_I2C_APPS_CLK_SRC 11 > +#define BLSP1_QUP2_SPI_APPS_CLK_SRC 12 > +#define BLSP1_QUP3_I2C_APPS_CLK_SRC 13 > +#define BLSP1_QUP3_SPI_APPS_CLK_SRC 14 > +#define BLSP1_QUP4_I2C_APPS_CLK_SRC 15 > +#define BLSP1_QUP4_SPI_APPS_CLK_SRC 16 > +#define BLSP1_QUP5_I2C_APPS_CLK_SRC 17 > +#define BLSP1_QUP5_SPI_APPS_CLK_SRC 18 > +#define BLSP1_QUP6_I2C_APPS_CLK_SRC 19 > +#define BLSP1_QUP6_SPI_APPS_CLK_SRC 20 > +#define BLSP1_UART1_APPS_CLK_SRC 21 > +#define BLSP1_UART2_APPS_CLK_SRC 22 > +#define BLSP1_UART3_APPS_CLK_SRC 23 > +#define BLSP1_UART4_APPS_CLK_SRC 24 > +#define BLSP1_UART5_APPS_CLK_SRC 25 > +#define BLSP1_UART6_APPS_CLK_SRC 26 > +#define GCC_APSS_AHB_CLK 27 > +#define GCC_APSS_AXI_CLK 28 > +#define GCC_BLSP1_QUP1_I2C_APPS_CLK 29 > +#define GCC_BLSP1_QUP1_SPI_APPS_CLK 30 > +#define GCC_BLSP1_QUP2_I2C_APPS_CLK 31 > +#define GCC_BLSP1_QUP2_SPI_APPS_CLK 32 > +#define GCC_BLSP1_QUP3_I2C_APPS_CLK 33 > +#define GCC_BLSP1_QUP3_SPI_APPS_CLK 34 > +#define GCC_BLSP1_QUP4_I2C_APPS_CLK 35 > +#define GCC_BLSP1_QUP4_SPI_APPS_CLK 36 > +#define GCC_BLSP1_QUP5_I2C_APPS_CLK 37 > +#define GCC_BLSP1_QUP5_SPI_APPS_CLK 38 > +#define GCC_BLSP1_QUP6_I2C_APPS_CLK 39 > +#define GCC_BLSP1_QUP6_SPI_APPS_CLK 40 > +#define GCC_BLSP1_UART1_APPS_CLK 41 > +#define GCC_BLSP1_UART2_APPS_CLK 42 > +#define GCC_BLSP1_UART3_APPS_CLK 43 > +#define GCC_BLSP1_UART4_APPS_CLK 44 > +#define GCC_BLSP1_UART5_APPS_CLK 45 > +#define GCC_BLSP1_UART6_APPS_CLK 46 > +#define PCIE0_AXI_M_CLK_SRC 47 > +#define GCC_PCIE0_AXI_M_CLK 48 > +#define PCIE1_AXI_M_CLK_SRC 49 > +#define GCC_PCIE1_AXI_M_CLK 50 > +#define PCIE2_AXI_M_CLK_SRC 51 > +#define GCC_PCIE2_AXI_M_CLK 52 > +#define PCIE3_AXI_M_CLK_SRC 53 > +#define GCC_PCIE3_AXI_M_CLK 54 > +#define PCIE0_AXI_S_CLK_SRC 55 > +#define GCC_PCIE0_AXI_S_BRIDGE_CLK 56 > +#define GCC_PCIE0_AXI_S_CLK 57 > +#define PCIE1_AXI_S_CLK_SRC 58 > +#define GCC_PCIE1_AXI_S_BRIDGE_CLK 59 > +#define GCC_PCIE1_AXI_S_CLK 60 > +#define PCIE2_AXI_S_CLK_SRC 61 > +#define GCC_PCIE2_AXI_S_BRIDGE_CLK 62 > +#define GCC_PCIE2_AXI_S_CLK 63 > +#define PCIE3_AXI_S_CLK_SRC 64 > +#define GCC_PCIE3_AXI_S_BRIDGE_CLK 65 > +#define GCC_PCIE3_AXI_S_CLK 66 > +#define PCIE0_PIPE_CLK_SRC 67 > +#define PCIE1_PIPE_CLK_SRC 68 > +#define PCIE2_PIPE_CLK_SRC 69 > +#define PCIE3_PIPE_CLK_SRC 70 > +#define PCIE_AUX_CLK_SRC 71 > +#define GCC_PCIE0_AUX_CLK 72 > +#define GCC_PCIE1_AUX_CLK 73 > +#define GCC_PCIE2_AUX_CLK 74 > +#define GCC_PCIE3_AUX_CLK 75 > +#define PCIE0_RCHNG_CLK_SRC 76 > +#define GCC_PCIE0_RCHNG_CLK 77 > +#define PCIE1_RCHNG_CLK_SRC 78 > +#define GCC_PCIE1_RCHNG_CLK 79 > +#define PCIE2_RCHNG_CLK_SRC 80 > +#define GCC_PCIE2_RCHNG_CLK 81 > +#define PCIE3_RCHNG_CLK_SRC 82 > +#define GCC_PCIE3_RCHNG_CLK 83 > +#define GCC_PCIE0_AHB_CLK 84 > +#define GCC_PCIE1_AHB_CLK 85 > +#define GCC_PCIE2_AHB_CLK 86 > +#define GCC_PCIE3_AHB_CLK 87 > +#define USB0_AUX_CLK_SRC 88 > +#define GCC_USB0_AUX_CLK 89 > +#define USB0_MASTER_CLK_SRC 90 > +#define GCC_USB0_MASTER_CLK 91 > +#define GCC_SNOC_USB_CLK 92 > +#define GCC_ANOC_USB_AXI_CLK 93 > +#define USB0_MOCK_UTMI_CLK_SRC 94 > +#define USB0_MOCK_UTMI_DIV_CLK_SRC 95 > +#define GCC_USB0_MOCK_UTMI_CLK 96 > +#define USB0_PIPE_CLK_SRC 97 > +#define GCC_USB0_PHY_CFG_AHB_CLK 98 > +#define SDCC1_APPS_CLK_SRC 99 > +#define GCC_SDCC1_APPS_CLK 100 > +#define SDCC1_ICE_CORE_CLK_SRC 101 > +#define GCC_SDCC1_ICE_CORE_CLK 102 > +#define GCC_SDCC1_AHB_CLK 103 > +#define PCNOC_BFDCD_CLK_SRC 104 > +#define GCC_NSSCFG_CLK 105 > +#define GCC_NSSNOC_NSSCC_CLK 106 > +#define GCC_NSSCC_CLK 107 > +#define GCC_NSSNOC_PCNOC_1_CLK 108 > +#define GCC_QDSS_DAP_AHB_CLK 109 > +#define GCC_QDSS_CFG_AHB_CLK 110 > +#define GCC_QPIC_AHB_CLK 111 > +#define GCC_QPIC_CLK 112 > +#define GCC_BLSP1_AHB_CLK 113 > +#define GCC_MDIO_AHB_CLK 114 > +#define GCC_PRNG_AHB_CLK 115 > +#define GCC_UNIPHY0_AHB_CLK 116 > +#define GCC_UNIPHY1_AHB_CLK 117 > +#define GCC_UNIPHY2_AHB_CLK 118 > +#define GCC_CMN_12GPLL_AHB_CLK 119 > +#define GCC_CMN_12GPLL_APU_CLK 120 > +#define SYSTEM_NOC_BFDCD_CLK_SRC 121 > +#define GCC_NSSNOC_SNOC_CLK 122 > +#define GCC_NSSNOC_SNOC_1_CLK 123 > +#define GCC_QDSS_ETR_USB_CLK 124 > +#define WCSS_AHB_CLK_SRC 125 > +#define GCC_Q6_AHB_CLK 126 > +#define GCC_Q6_AHB_S_CLK 127 > +#define GCC_WCSS_ECAHB_CLK 128 > +#define GCC_WCSS_ACMT_CLK 129 > +#define GCC_SYS_NOC_WCSS_AHB_CLK 130 > +#define WCSS_AXI_M_CLK_SRC 131 > +#define GCC_ANOC_WCSS_AXI_M_CLK 132 > +#define QDSS_AT_CLK_SRC 133 > +#define GCC_Q6SS_ATBM_CLK 134 > +#define GCC_WCSS_DBG_IFC_ATB_CLK 135 > +#define GCC_NSSNOC_ATB_CLK 136 > +#define GCC_QDSS_AT_CLK 137 > +#define GCC_SYS_NOC_AT_CLK 138 > +#define GCC_PCNOC_AT_CLK 139 > +#define GCC_USB0_EUD_AT_CLK 140 > +#define GCC_QDSS_EUD_AT_CLK 141 > +#define QDSS_STM_CLK_SRC 142 > +#define GCC_QDSS_STM_CLK 143 > +#define GCC_SYS_NOC_QDSS_STM_AXI_CLK 144 > +#define QDSS_TRACECLKIN_CLK_SRC 145 > +#define GCC_QDSS_TRACECLKIN_CLK 146 > +#define QDSS_TSCTR_CLK_SRC 147 > +#define GCC_Q6_TSCTR_1TO2_CLK 148 > +#define GCC_WCSS_DBG_IFC_NTS_CLK 149 > +#define GCC_QDSS_TSCTR_DIV2_CLK 150 > +#define GCC_QDSS_TS_CLK 151 > +#define GCC_QDSS_TSCTR_DIV4_CLK 152 > +#define GCC_NSS_TS_CLK 153 > +#define GCC_QDSS_TSCTR_DIV8_CLK 154 > +#define GCC_QDSS_TSCTR_DIV16_CLK 155 > +#define GCC_Q6SS_PCLKDBG_CLK 156 > +#define GCC_Q6SS_TRIG_CLK 157 > +#define GCC_WCSS_DBG_IFC_APB_CLK 158 > +#define GCC_WCSS_DBG_IFC_DAPBUS_CLK 159 > +#define GCC_QDSS_DAP_CLK 160 > +#define GCC_QDSS_APB2JTAG_CLK 161 > +#define GCC_QDSS_TSCTR_DIV3_CLK 162 > +#define QPIC_IO_MACRO_CLK_SRC 163 > +#define GCC_QPIC_IO_MACRO_CLK 164 > +#define Q6_AXI_CLK_SRC 165 > +#define GCC_Q6_AXIM_CLK 166 > +#define GCC_WCSS_Q6_TBU_CLK 167 > +#define GCC_MEM_NOC_Q6_AXI_CLK 168 > +#define Q6_AXIM2_CLK_SRC 169 > +#define NSSNOC_MEMNOC_BFDCD_CLK_SRC 170 > +#define GCC_NSSNOC_MEMNOC_CLK 171 > +#define GCC_NSSNOC_MEM_NOC_1_CLK 172 > +#define GCC_NSS_TBU_CLK 173 > +#define GCC_MEM_NOC_NSSNOC_CLK 174 > +#define LPASS_AXIM_CLK_SRC 175 > +#define LPASS_SWAY_CLK_SRC 176 > +#define ADSS_PWM_CLK_SRC 177 > +#define GCC_ADSS_PWM_CLK 178 > +#define GP1_CLK_SRC 179 > +#define GP2_CLK_SRC 180 > +#define GP3_CLK_SRC 181 > +#define DDRSS_SMS_SLOW_CLK_SRC 182 > +#define GCC_XO_CLK_SRC 183 > +#define GCC_XO_CLK 184 > +#define GCC_NSSNOC_QOSGEN_REF_CLK 185 > +#define GCC_NSSNOC_TIMEOUT_REF_CLK 186 > +#define GCC_XO_DIV4_CLK 187 > +#define GCC_UNIPHY0_SYS_CLK 188 > +#define GCC_UNIPHY1_SYS_CLK 189 > +#define GCC_UNIPHY2_SYS_CLK 190 > +#define GCC_CMN_12GPLL_SYS_CLK 191 > +#define GCC_NSSNOC_XO_DCD_CLK 192 > +#define GCC_Q6SS_BOOT_CLK 193 > +#define UNIPHY_SYS_CLK_SRC 194 > +#define NSS_TS_CLK_SRC 195 > +#define GCC_ANOC_PCIE0_1LANE_M_CLK 196 > +#define GCC_ANOC_PCIE1_1LANE_M_CLK 197 > +#define GCC_ANOC_PCIE2_2LANE_M_CLK 198 > +#define GCC_ANOC_PCIE3_2LANE_M_CLK 199 > +#define GCC_SNOC_PCIE0_1LANE_S_CLK 200 > +#define GCC_SNOC_PCIE1_1LANE_S_CLK 201 > +#define GCC_SNOC_PCIE2_2LANE_S_CLK 202 > +#define GCC_SNOC_PCIE3_2LANE_S_CLK 203 > +#endif > diff --git a/include/dt-bindings/reset/qcom,ipq9574-gcc.h b/include/dt-bindings/reset/qcom,ipq9574-gcc.h > new file mode 100644 > index 000000000000..a11adbda45ec > --- /dev/null > +++ b/include/dt-bindings/reset/qcom,ipq9574-gcc.h > @@ -0,0 +1,164 @@ > +/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) */ > +/* > + * Copyright (c) 2018-2023, The Linux Foundation. All rights reserved. > + */ > + > +#ifndef _DT_BINDINGS_RESET_IPQ_GCC_9048_H > +#define _DT_BINDINGS_RESET_IPQ_GCC_9048_H > + > +#define GCC_ADSS_BCR 0 > +#define GCC_APC0_VOLTAGE_DROOP_DETECTOR_BCR 1 > +#define GCC_BLSP1_BCR 2 > +#define GCC_BLSP1_QUP1_BCR 3 > +#define GCC_BLSP1_QUP2_BCR 4 > +#define GCC_BLSP1_QUP3_BCR 5 > +#define GCC_BLSP1_QUP4_BCR 6 > +#define GCC_BLSP1_QUP5_BCR 7 > +#define GCC_BLSP1_QUP6_BCR 8 > +#define GCC_BLSP1_UART1_BCR 9 > +#define GCC_BLSP1_UART2_BCR 10 > +#define GCC_BLSP1_UART3_BCR 11 > +#define GCC_BLSP1_UART4_BCR 12 > +#define GCC_BLSP1_UART5_BCR 13 > +#define GCC_BLSP1_UART6_BCR 14 > +#define GCC_BOOT_ROM_BCR 15 > +#define GCC_MDIO_BCR 16 > +#define GCC_NSS_BCR 17 > +#define GCC_NSS_TBU_BCR 18 > +#define GCC_PCIE0_BCR 19 > +#define GCC_PCIE0_LINK_DOWN_BCR 20 > +#define GCC_PCIE0_PHY_BCR 21 > +#define GCC_PCIE0PHY_PHY_BCR 22 > +#define GCC_PCIE1_BCR 23 > +#define GCC_PCIE1_LINK_DOWN_BCR 24 > +#define GCC_PCIE1_PHY_BCR 25 > +#define GCC_PCIE1PHY_PHY_BCR 26 > +#define GCC_PCIE2_BCR 27 > +#define GCC_PCIE2_LINK_DOWN_BCR 28 > +#define GCC_PCIE2_PHY_BCR 29 > +#define GCC_PCIE2PHY_PHY_BCR 30 > +#define GCC_PCIE3_BCR 31 > +#define GCC_PCIE3_LINK_DOWN_BCR 32 > +#define GCC_PCIE3_PHY_BCR 33 > +#define GCC_PCIE3PHY_PHY_BCR 34 > +#define GCC_PRNG_BCR 35 > +#define GCC_QUSB2_0_PHY_BCR 36 > +#define GCC_SDCC_BCR 37 > +#define GCC_TLMM_BCR 38 > +#define GCC_UNIPHY0_BCR 39 > +#define GCC_UNIPHY1_BCR 40 > +#define GCC_UNIPHY2_BCR 41 > +#define GCC_USB0_PHY_BCR 42 > +#define GCC_USB3PHY_0_PHY_BCR 43 > +#define GCC_USB_BCR 44 > +#define GCC_ANOC0_TBU_BCR 45 > +#define GCC_ANOC1_TBU_BCR 46 > +#define GCC_ANOC_BCR 47 > +#define GCC_APSS_TCU_BCR 48 > +#define GCC_CMN_BLK_BCR 49 > +#define GCC_CMN_BLK_AHB_ARES 50 > +#define GCC_CMN_BLK_SYS_ARES 51 > +#define GCC_CMN_BLK_APU_ARES 52 > +#define GCC_DCC_BCR 53 > +#define GCC_DDRSS_BCR 54 > +#define GCC_IMEM_BCR 55 > +#define GCC_LPASS_BCR 56 > +#define GCC_MPM_BCR 57 > +#define GCC_MSG_RAM_BCR 58 > +#define GCC_NSSNOC_MEMNOC_1_ARES 59 > +#define GCC_NSSNOC_PCNOC_1_ARES 60 > +#define GCC_NSSNOC_SNOC_1_ARES 61 > +#define GCC_NSSNOC_XO_DCD_ARES 62 > +#define GCC_NSSNOC_TS_ARES 63 > +#define GCC_NSSCC_ARES 64 > +#define GCC_NSSNOC_NSSCC_ARES 65 > +#define GCC_NSSNOC_ATB_ARES 66 > +#define GCC_NSSNOC_MEMNOC_ARES 67 > +#define GCC_NSSNOC_QOSGEN_REF_ARES 68 > +#define GCC_NSSNOC_SNOC_ARES 69 > +#define GCC_NSSNOC_TIMEOUT_REF_ARES 70 > +#define GCC_NSS_CFG_ARES 71 > +#define GCC_UBI0_DBG_ARES 72 > +#define GCC_PCIE0_AHB_ARES 73 > +#define GCC_PCIE0_AUX_ARES 74 > +#define GCC_PCIE0_AXI_M_ARES 75 > +#define GCC_PCIE0_AXI_M_STICKY_ARES 76 > +#define GCC_PCIE0_AXI_S_ARES 77 > +#define GCC_PCIE0_AXI_S_STICKY_ARES 78 > +#define GCC_PCIE0_CORE_STICKY_ARES 79 > +#define GCC_PCIE0_PIPE_ARES 80 > +#define GCC_PCIE1_AHB_ARES 81 > +#define GCC_PCIE1_AUX_ARES 82 > +#define GCC_PCIE1_AXI_M_ARES 83 > +#define GCC_PCIE1_AXI_M_STICKY_ARES 84 > +#define GCC_PCIE1_AXI_S_ARES 85 > +#define GCC_PCIE1_AXI_S_STICKY_ARES 86 > +#define GCC_PCIE1_CORE_STICKY_ARES 87 > +#define GCC_PCIE1_PIPE_ARES 88 > +#define GCC_PCIE2_AHB_ARES 89 > +#define GCC_PCIE2_AUX_ARES 90 > +#define GCC_PCIE2_AXI_M_ARES 91 > +#define GCC_PCIE2_AXI_M_STICKY_ARES 92 > +#define GCC_PCIE2_AXI_S_ARES 93 > +#define GCC_PCIE2_AXI_S_STICKY_ARES 94 > +#define GCC_PCIE2_CORE_STICKY_ARES 95 > +#define GCC_PCIE2_PIPE_ARES 96 > +#define GCC_PCIE3_AHB_ARES 97 > +#define GCC_PCIE3_AUX_ARES 98 > +#define GCC_PCIE3_AXI_M_ARES 99 > +#define GCC_PCIE3_AXI_M_STICKY_ARES 100 > +#define GCC_PCIE3_AXI_S_ARES 101 > +#define GCC_PCIE3_AXI_S_STICKY_ARES 102 > +#define GCC_PCIE3_CORE_STICKY_ARES 103 > +#define GCC_PCIE3_PIPE_ARES 104 > +#define GCC_PCNOC_BCR 105 > +#define GCC_PCNOC_BUS_TIMEOUT0_BCR 106 > +#define GCC_PCNOC_BUS_TIMEOUT1_BCR 107 > +#define GCC_PCNOC_BUS_TIMEOUT2_BCR 108 > +#define GCC_PCNOC_BUS_TIMEOUT3_BCR 109 > +#define GCC_PCNOC_BUS_TIMEOUT4_BCR 110 > +#define GCC_PCNOC_BUS_TIMEOUT5_BCR 111 > +#define GCC_PCNOC_BUS_TIMEOUT6_BCR 112 > +#define GCC_PCNOC_BUS_TIMEOUT7_BCR 113 > +#define GCC_PCNOC_BUS_TIMEOUT8_BCR 114 > +#define GCC_PCNOC_BUS_TIMEOUT9_BCR 115 > +#define GCC_PCNOC_TBU_BCR 116 > +#define GCC_Q6SS_DBG_ARES 117 > +#define GCC_Q6_AHB_ARES 118 > +#define GCC_Q6_AHB_S_ARES 119 > +#define GCC_Q6_AXIM2_ARES 120 > +#define GCC_Q6_AXIM_ARES 121 > +#define GCC_QDSS_BCR 122 > +#define GCC_QPIC_BCR 123 > +#define GCC_QPIC_AHB_ARES 124 > +#define GCC_QPIC_ARES 125 > +#define GCC_RBCPR_BCR 126 > +#define GCC_RBCPR_MX_BCR 127 > +#define GCC_SEC_CTRL_BCR 128 > +#define GCC_SMMU_CFG_BCR 129 > +#define GCC_SNOC_BCR 130 > +#define GCC_SPDM_BCR 131 > +#define GCC_TME_BCR 132 > +#define GCC_UNIPHY0_SYS_RESET 133 > +#define GCC_UNIPHY0_AHB_RESET 134 > +#define GCC_UNIPHY0_XPCS_RESET 135 > +#define GCC_UNIPHY1_SYS_RESET 136 > +#define GCC_UNIPHY1_AHB_RESET 137 > +#define GCC_UNIPHY1_XPCS_RESET 138 > +#define GCC_UNIPHY2_SYS_RESET 139 > +#define GCC_UNIPHY2_AHB_RESET 140 > +#define GCC_UNIPHY2_XPCS_RESET 141 > +#define GCC_USB_MISC_RESET 142 > +#define GCC_WCSSAON_RESET 143 > +#define GCC_WCSS_ACMT_ARES 144 > +#define GCC_WCSS_AHB_S_ARES 145 > +#define GCC_WCSS_AXI_M_ARES 146 > +#define GCC_WCSS_BCR 147 > +#define GCC_WCSS_DBG_ARES 148 > +#define GCC_WCSS_DBG_BDG_ARES 149 > +#define GCC_WCSS_ECAHB_ARES 150 > +#define GCC_WCSS_Q6_BCR 151 > +#define GCC_WCSS_Q6_TBU_BCR 152 > +#define GCC_TCSR_BCR 153 > + > +#endif
On 1/24/2023 8:38 PM, Krzysztof Kozlowski wrote: > On 24/01/2023 15:15, devi priya wrote: >> Document the pinctrl driver for IPQ9574 >> >> Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> >> Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> >> Signed-off-by: devi priya <quic_devipriy@quicinc.com> > > Did anything changed here? > Have rebased the binding on the recent changes as sugggested > b4 diff fails on this patch, there is no detailed changelog. > > Subject looks not fixed - why "driver" appeared there? Bindings do not > document driver. > Sure, will update the subject, add the changelogs and post V3 patch series > Best regards, > Krzysztof > Best Regards, Devi Priya
On 1/24/2023 10:41 PM, Dmitry Baryshkov wrote: > On Tue, 24 Jan 2023 at 16:17, devi priya <quic_devipriy@quicinc.com> wrote: >> >> From: Poovendhan Selvaraj <quic_poovendh@quicinc.com> >> >> Add initial device tree support for Qualcomm IPQ9574 SoC >> and AL02 board >> >> Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> >> Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> >> Co-developed-by: devi priya <quic_devipriy@quicinc.com> >> Signed-off-by: devi priya <quic_devipriy@quicinc.com> >> Signed-off-by: Poovendhan Selvaraj <quic_poovendh@quicinc.com> > > > I suspect that the order of sign-offs is incorrect here. Your sign-off > should be the last one, as you are the person sending the patch. > > Sure, will update Best Regards, Devi Priya
On 24/01/2023 15:15, devi priya wrote: > Document the pinctrl driver for IPQ9574 > > Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> > Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> > Signed-off-by: devi priya <quic_devipriy@quicinc.com> > --- > .../bindings/pinctrl/qcom,ipq9574-tlmm.yaml | 135 ++++++++++++++++++ > 1 file changed, 135 insertions(+) > create mode 100644 Documentation/devicetree/bindings/pinctrl/qcom,ipq9574-tlmm.yaml > > diff --git a/Documentation/devicetree/bindings/pinctrl/qcom,ipq9574-tlmm.yaml b/Documentation/devicetree/bindings/pinctrl/qcom,ipq9574-tlmm.yaml > new file mode 100644 > index 000000000000..d736f0fb7835 > --- /dev/null > +++ b/Documentation/devicetree/bindings/pinctrl/qcom,ipq9574-tlmm.yaml > @@ -0,0 +1,135 @@ > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > +%YAML 1.2 > +--- > +$id: http://devicetree.org/schemas/pinctrl/qcom,ipq9574-tlmm.yaml# > +$schema: http://devicetree.org/meta-schemas/core.yaml# > + > +title: Qualcomm Technologies, Inc. IPQ9574 TLMM block > + > +maintainers: > + - Bjorn Andersson <andersson@kernel.org> > + - Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> > + > +description: > + Top Level Mode Multiplexer pin controller in Qualcomm IPQ9574 SoC. > + > +properties: > + compatible: > + const: qcom,ipq9574-tlmm > + > + reg: > + maxItems: 1 > + > + interrupts: true Also - missing maxItems. I think you based your patches on some older version, so you might miss here changes we did recently. Best regards, Krzysztof
On 1/24/2023 8:02 PM, Krzysztof Kozlowski wrote: > On 24/01/2023 15:15, devi priya wrote: >> The IPQ9574 is Qualcomm's 802.11ax SoC for Routers, >> Gateways and Access Points. >> >> This series adds minimal board boot support for ipq9574-al02-c7 board >> >> [V1] > > You already sent a v1. This should be v2. > >> Fixed all the review comments > > That's not specific enough. > Okay, got it. Will add the changelogs, address few minor comments on this series and post V3 > Best regards, > Krzysztof > Best Regards, Devi Priya
On 1/24/2023 8:44 PM, Krzysztof Kozlowski wrote: > On 24/01/2023 15:15, devi priya wrote: >> From: Poovendhan Selvaraj <quic_poovendh@quicinc.com> >> >> Add initial device tree support for Qualcomm IPQ9574 SoC >> and AL02 board >> >> Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> >> Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> >> Co-developed-by: devi priya <quic_devipriy@quicinc.com> >> Signed-off-by: devi priya <quic_devipriy@quicinc.com> >> Signed-off-by: Poovendhan Selvaraj <quic_poovendh@quicinc.com> >> --- >> arch/arm64/boot/dts/qcom/Makefile | 1 + >> arch/arm64/boot/dts/qcom/ipq9574-al02-c7.dts | 78 +++++ >> arch/arm64/boot/dts/qcom/ipq9574.dtsi | 285 +++++++++++++++++++ >> 3 files changed, 364 insertions(+) >> create mode 100644 arch/arm64/boot/dts/qcom/ipq9574-al02-c7.dts >> create mode 100644 arch/arm64/boot/dts/qcom/ipq9574.dtsi >> >> diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile >> index 3e79496292e7..872c62028a0b 100644 >> --- a/arch/arm64/boot/dts/qcom/Makefile >> +++ b/arch/arm64/boot/dts/qcom/Makefile >> @@ -7,6 +7,7 @@ dtb-$(CONFIG_ARCH_QCOM) += ipq6018-cp01-c1.dtb >> dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk01.dtb >> dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk10-c1.dtb >> dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk10-c2.dtb >> +dtb-$(CONFIG_ARCH_QCOM) += ipq9574-al02-c7.dtb >> dtb-$(CONFIG_ARCH_QCOM) += msm8916-alcatel-idol347.dtb > > This does not match current tree, so I could not apply it for tests. I > think you based it on a bit older version. > The patch series is based on Linux 6.2-rc1 and not the qcom/for-next branch. > Best regards, > Krzysztof > Best Regards, Devi Priya
On 25.01.2023 12:12, Devi Priya wrote: > > > On 1/24/2023 8:44 PM, Krzysztof Kozlowski wrote: >> On 24/01/2023 15:15, devi priya wrote: >>> From: Poovendhan Selvaraj <quic_poovendh@quicinc.com> >>> >>> Add initial device tree support for Qualcomm IPQ9574 SoC >>> and AL02 board >>> >>> Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> >>> Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> >>> Co-developed-by: devi priya <quic_devipriy@quicinc.com> >>> Signed-off-by: devi priya <quic_devipriy@quicinc.com> >>> Signed-off-by: Poovendhan Selvaraj <quic_poovendh@quicinc.com> >>> --- >>> arch/arm64/boot/dts/qcom/Makefile | 1 + >>> arch/arm64/boot/dts/qcom/ipq9574-al02-c7.dts | 78 +++++ >>> arch/arm64/boot/dts/qcom/ipq9574.dtsi | 285 +++++++++++++++++++ >>> 3 files changed, 364 insertions(+) >>> create mode 100644 arch/arm64/boot/dts/qcom/ipq9574-al02-c7.dts >>> create mode 100644 arch/arm64/boot/dts/qcom/ipq9574.dtsi >>> >>> diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile >>> index 3e79496292e7..872c62028a0b 100644 >>> --- a/arch/arm64/boot/dts/qcom/Makefile >>> +++ b/arch/arm64/boot/dts/qcom/Makefile >>> @@ -7,6 +7,7 @@ dtb-$(CONFIG_ARCH_QCOM) += ipq6018-cp01-c1.dtb >>> dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk01.dtb >>> dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk10-c1.dtb >>> dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk10-c2.dtb >>> +dtb-$(CONFIG_ARCH_QCOM) += ipq9574-al02-c7.dtb >>> dtb-$(CONFIG_ARCH_QCOM) += msm8916-alcatel-idol347.dtb >> >> This does not match current tree, so I could not apply it for tests. I >> think you based it on a bit older version. >> > The patch series is based on Linux 6.2-rc1 and not the qcom/for-next branch. Linux 6.2-rc1 is very old already and Bjorn has already picked tens of patches atop it, so yours will not apply unless you base it on qcom/for-next (or just linux-next for that matter). Konrad >> Best regards, >> Krzysztof >> > Best Regards, > Devi Priya
On 24.01.2023 15:15, devi priya wrote: > Add Global Clock Controller (GCC) driver for ipq9574 based devices > > Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> > Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> > Signed-off-by: devi priya <quic_devipriy@quicinc.com> > --- > drivers/clk/qcom/Kconfig | 8 + > drivers/clk/qcom/Makefile | 1 + > drivers/clk/qcom/gcc-ipq9574.c | 4301 ++++++++++++++++++++++++++++++++ > 3 files changed, 4310 insertions(+) > create mode 100644 drivers/clk/qcom/gcc-ipq9574.c > > diff --git a/drivers/clk/qcom/Kconfig b/drivers/clk/qcom/Kconfig > index 70d43f0a8919..97517d1e3ba4 100644 > --- a/drivers/clk/qcom/Kconfig > +++ b/drivers/clk/qcom/Kconfig > @@ -173,6 +173,14 @@ config IPQ_GCC_8074 > i2c, USB, SD/eMMC, etc. Select this for the root clock > of ipq8074. > > +config IPQ_GCC_9574 > + tristate "IPQ9574 Global Clock Controller" > + help > + Support for global clock controller on ipq9574 devices. > + Say Y if you want to use peripheral devices such as UART, SPI, > + i2c, USB, SD/eMMC, etc. Select this for the root clock > + of ipq9574. > + > config MSM_GCC_8660 > tristate "MSM8660 Global Clock Controller" > help > diff --git a/drivers/clk/qcom/Makefile b/drivers/clk/qcom/Makefile > index f18c446a97ea..55c6ada326e0 100644 > --- a/drivers/clk/qcom/Makefile > +++ b/drivers/clk/qcom/Makefile > @@ -27,6 +27,7 @@ obj-$(CONFIG_IPQ_GCC_4019) += gcc-ipq4019.o > obj-$(CONFIG_IPQ_GCC_6018) += gcc-ipq6018.o > obj-$(CONFIG_IPQ_GCC_806X) += gcc-ipq806x.o > obj-$(CONFIG_IPQ_GCC_8074) += gcc-ipq8074.o > +obj-$(CONFIG_IPQ_GCC_9574) += gcc-ipq9574.o > obj-$(CONFIG_IPQ_LCC_806X) += lcc-ipq806x.o > obj-$(CONFIG_MDM_GCC_9607) += gcc-mdm9607.o > obj-$(CONFIG_MDM_GCC_9615) += gcc-mdm9615.o > diff --git a/drivers/clk/qcom/gcc-ipq9574.c b/drivers/clk/qcom/gcc-ipq9574.c > new file mode 100644 > index 000000000000..6b3509e5f90e > --- /dev/null > +++ b/drivers/clk/qcom/gcc-ipq9574.c > @@ -0,0 +1,4301 @@ > +// SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > +/* > + * Copyright (c) 2023 The Linux Foundation. All rights reserved. > + */ > + [...] > +static struct clk_branch gcc_apss_ahb_clk = { > + .halt_reg = 0x24018, > + .halt_check = BRANCH_HALT_VOTED, > + .clkr = { > + .enable_reg = 0x0b004, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_apss_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &apss_ahb_clk_src.clkr.hw Wrong indentation, there's quite a few occurences, please take care of that. > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + [...] > + > +static struct clk_rcg2 pcnoc_bfdcd_clk_src = { Doesn't RPM scale the interconnect clocks on this platform? By the way, it seems rather strange that you did not add RPM(h) support at all with this series.. If it does, it may be worth dropping them as they're pretty much unnecessary fluff that may fight with the internal RPM voters for "whose rate is the best rate".. Konrad > + .cmd_rcgr = 0x31004, > + .freq_tbl = ftbl_pcnoc_bfdcd_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "pcnoc_bfdcd_clk_src", > + .parent_data = gcc_xo_gpll0_gpll0_out_main_div2, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_out_main_div2), > + .flags = CLK_IS_CRITICAL, > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_nsscfg_clk = { > + .halt_reg = 0x1702c, > + .clkr = { > + .enable_reg = 0x1702c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nsscfg_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_nssnoc_nsscc_clk = { > + .halt_reg = 0x17030, > + .clkr = { > + .enable_reg = 0x17030, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nssnoc_nsscc_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_nsscc_clk = { > + .halt_reg = 0x17034, > + .clkr = { > + .enable_reg = 0x17034, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nsscc_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_nssnoc_pcnoc_1_clk = { > + .halt_reg = 0x17080, > + .clkr = { > + .enable_reg = 0x17080, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nssnoc_pcnoc_1_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_qdss_dap_ahb_clk = { > + .halt_reg = 0x2d064, > + .clkr = { > + .enable_reg = 0x2d064, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_dap_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_qdss_cfg_ahb_clk = { > + .halt_reg = 0x2d068, > + .clkr = { > + .enable_reg = 0x2d068, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_cfg_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_qpic_ahb_clk = { > + .halt_reg = 0x32010, > + .clkr = { > + .enable_reg = 0x32010, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qpic_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_qpic_clk = { > + .halt_reg = 0x32014, > + .clkr = { > + .enable_reg = 0x32014, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qpic_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_blsp1_ahb_clk = { > + .halt_reg = 0x01004, > + .halt_check = BRANCH_HALT_VOTED, > + .clkr = { > + .enable_reg = 0x0b004, > + .enable_mask = BIT(4), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_blsp1_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_mdio_ahb_clk = { > + .halt_reg = 0x17040, > + .clkr = { > + .enable_reg = 0x17040, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_mdio_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_prng_ahb_clk = { > + .halt_reg = 0x13024, > + .halt_check = BRANCH_HALT_VOTED, > + .clkr = { > + .enable_reg = 0x0b004, > + .enable_mask = BIT(10), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_prng_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_uniphy0_ahb_clk = { > + .halt_reg = 0x1704c, > + .clkr = { > + .enable_reg = 0x1704c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_uniphy0_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_uniphy1_ahb_clk = { > + .halt_reg = 0x1705c, > + .clkr = { > + .enable_reg = 0x1705c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_uniphy1_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_uniphy2_ahb_clk = { > + .halt_reg = 0x1706c, > + .clkr = { > + .enable_reg = 0x1706c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_uniphy2_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_cmn_12gpll_ahb_clk = { > + .halt_reg = 0x3a004, > + .clkr = { > + .enable_reg = 0x3a004, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_cmn_12gpll_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_cmn_12gpll_apu_clk = { > + .halt_reg = 0x3a00c, > + .clkr = { > + .enable_reg = 0x3a00c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_cmn_12gpll_apu_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_pcie0_ahb_clk = { > + .halt_reg = 0x28030, > + .clkr = { > + .enable_reg = 0x28030, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_pcie0_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_pcie1_ahb_clk = { > + .halt_reg = 0x29030, > + .clkr = { > + .enable_reg = 0x29030, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_pcie1_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_pcie2_ahb_clk = { > + .halt_reg = 0x2a030, > + .clkr = { > + .enable_reg = 0x2a030, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_pcie2_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_pcie3_ahb_clk = { > + .halt_reg = 0x2b030, > + .clkr = { > + .enable_reg = 0x2b030, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_pcie3_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_usb0_phy_cfg_ahb_clk = { > + .halt_reg = 0x2c05c, > + .clkr = { > + .enable_reg = 0x2c05c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_usb0_phy_cfg_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_sdcc1_ahb_clk = { > + .halt_reg = 0x33034, > + .clkr = { > + .enable_reg = 0x33034, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_sdcc1_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &pcnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_system_noc_bfdcd_clk_src[] = { > + F(24000000, P_XO, 1, 0, 0), > + F(133333333, P_GPLL0, 6, 0, 0), > + F(200000000, P_GPLL0, 4, 0, 0), > + F(342850000, P_GPLL4, 3.5, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 system_noc_bfdcd_clk_src = { > + .cmd_rcgr = 0x2e004, > + .freq_tbl = ftbl_system_noc_bfdcd_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_gpll4_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "system_noc_bfdcd_clk_src", > + .parent_data = gcc_xo_gpll0_gpll4, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll4), > + .flags = CLK_IS_CRITICAL, > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_q6ss_boot_clk = { > + .halt_reg = 0x25080, > + .halt_check = BRANCH_HALT_SKIP, > + .clkr = { > + .enable_reg = 0x25080, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_q6ss_boot_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &system_noc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_nssnoc_snoc_clk = { > + .halt_reg = 0x17028, > + .clkr = { > + .enable_reg = 0x17028, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nssnoc_snoc_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &system_noc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_nssnoc_snoc_1_clk = { > + .halt_reg = 0x1707c, > + .clkr = { > + .enable_reg = 0x1707c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nssnoc_snoc_1_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &system_noc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_qdss_etr_usb_clk = { > + .halt_reg = 0x2d060, > + .clkr = { > + .enable_reg = 0x2d060, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_etr_usb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &system_noc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_wcss_ahb_clk_src[] = { > + F(24000000, P_XO, 1, 0, 0), > + F(133333333, P_GPLL0, 6, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 wcss_ahb_clk_src = { > + .cmd_rcgr = 0x25030, > + .freq_tbl = ftbl_wcss_ahb_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "wcss_ahb_clk_src", > + .parent_data = gcc_xo_gpll0, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_q6_ahb_clk = { > + .halt_reg = 0x25014, > + .clkr = { > + .enable_reg = 0x25014, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_q6_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &wcss_ahb_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_q6_ahb_s_clk = { > + .halt_reg = 0x25018, > + .clkr = { > + .enable_reg = 0x25018, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_q6_ahb_s_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &wcss_ahb_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_wcss_ecahb_clk = { > + .halt_reg = 0x25058, > + .clkr = { > + .enable_reg = 0x25058, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_wcss_ecahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &wcss_ahb_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_wcss_acmt_clk = { > + .halt_reg = 0x2505c, > + .clkr = { > + .enable_reg = 0x2505c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_wcss_acmt_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &wcss_ahb_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_sys_noc_wcss_ahb_clk = { > + .halt_reg = 0x2e030, > + .clkr = { > + .enable_reg = 0x2e030, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_sys_noc_wcss_ahb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &wcss_ahb_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_wcss_axi_m_clk_src[] = { > + F(24000000, P_XO, 1, 0, 0), > + F(133333333, P_GPLL0, 6, 0, 0), > + F(266666667, P_GPLL0, 3, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 wcss_axi_m_clk_src = { > + .cmd_rcgr = 0x25078, > + .freq_tbl = ftbl_wcss_axi_m_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "wcss_axi_m_clk_src", > + .parent_data = gcc_xo_gpll0, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_anoc_wcss_axi_m_clk = { > + .halt_reg = 0x2e0a8, > + .clkr = { > + .enable_reg = 0x2e0a8, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_anoc_wcss_axi_m_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &wcss_axi_m_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_qdss_at_clk_src[] = { > + F(240000000, P_GPLL4, 5, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 qdss_at_clk_src = { > + .cmd_rcgr = 0x2d004, > + .freq_tbl = ftbl_qdss_at_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll4_gpll0_gpll0_div2_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "qdss_at_clk_src", > + .parent_data = gcc_xo_gpll4_gpll0_gpll0_div2, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll4_gpll0_gpll0_div2), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_q6ss_atbm_clk = { > + .halt_reg = 0x2501c, > + .clkr = { > + .enable_reg = 0x2501c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_q6ss_atbm_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_at_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_wcss_dbg_ifc_atb_clk = { > + .halt_reg = 0x2503c, > + .clkr = { > + .enable_reg = 0x2503c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_wcss_dbg_ifc_atb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_at_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_nssnoc_atb_clk = { > + .halt_reg = 0x17014, > + .clkr = { > + .enable_reg = 0x17014, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nssnoc_atb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_at_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_qdss_at_clk = { > + .halt_reg = 0x2d038, > + .clkr = { > + .enable_reg = 0x2d038, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_at_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_at_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_sys_noc_at_clk = { > + .halt_reg = 0x2e038, > + .clkr = { > + .enable_reg = 0x2e038, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_sys_noc_at_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_at_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_pcnoc_at_clk = { > + .halt_reg = 0x31024, > + .clkr = { > + .enable_reg = 0x31024, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_pcnoc_at_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_at_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_fixed_factor gcc_eud_at_div_clk_src = { > + .mult = 1, > + .div = 6, > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_eud_at_div_clk_src", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_at_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_fixed_factor_ops, > + }, > +}; > + > +static struct clk_branch gcc_usb0_eud_at_clk = { > + .halt_reg = 0x30004, > + .clkr = { > + .enable_reg = 0x30004, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_usb0_eud_at_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &gcc_eud_at_div_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_qdss_eud_at_clk = { > + .halt_reg = 0x2d06c, > + .clkr = { > + .enable_reg = 0x2d06c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_eud_at_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &gcc_eud_at_div_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_qdss_stm_clk_src[] = { > + F(24000000, P_XO, 1, 0, 0), > + F(200000000, P_GPLL0, 4, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 qdss_stm_clk_src = { > + .cmd_rcgr = 0x2d00c, > + .freq_tbl = ftbl_qdss_stm_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "qdss_stm_clk_src", > + .parent_data = gcc_xo_gpll0_gpll0_out_main_div2, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_out_main_div2), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_qdss_stm_clk = { > + .halt_reg = 0x2d03c, > + .clkr = { > + .enable_reg = 0x2d03c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_stm_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_stm_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_sys_noc_qdss_stm_axi_clk = { > + .halt_reg = 0x2e034, > + .clkr = { > + .enable_reg = 0x2e034, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_sys_noc_qdss_stm_axi_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_stm_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_qdss_traceclkin_clk_src[] = { > + F(300000000, P_GPLL4, 4, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 qdss_traceclkin_clk_src = { > + .cmd_rcgr = 0x2d014, > + .freq_tbl = ftbl_qdss_traceclkin_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll4_gpll0_gpll0_div2_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "qdss_traceclkin_clk_src", > + .parent_data = gcc_xo_gpll4_gpll0_gpll0_div2, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll4_gpll0_gpll0_div2), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_qdss_traceclkin_clk = { > + .halt_reg = 0x2d040, > + .clkr = { > + .enable_reg = 0x2d040, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_traceclkin_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_traceclkin_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_qdss_tsctr_clk_src[] = { > + F(600000000, P_GPLL4, 2, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 qdss_tsctr_clk_src = { > + .cmd_rcgr = 0x2d01c, > + .freq_tbl = ftbl_qdss_tsctr_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll4_gpll0_gpll0_div2_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "qdss_tsctr_clk_src", > + .parent_data = gcc_xo_gpll4_gpll0_gpll0_div2, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll4_gpll0_gpll0_div2), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_fixed_factor qdss_tsctr_div2_clk_src = { > + .mult = 1, > + .div = 2, > + .hw.init = &(struct clk_init_data) { > + .name = "qdss_tsctr_div2_clk_src", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_tsctr_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_fixed_factor_ops, > + }, > +}; > + > +static struct clk_branch gcc_q6_tsctr_1to2_clk = { > + .halt_reg = 0x25020, > + .clkr = { > + .enable_reg = 0x25020, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_q6_tsctr_1to2_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_tsctr_div2_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_wcss_dbg_ifc_nts_clk = { > + .halt_reg = 0x25040, > + .clkr = { > + .enable_reg = 0x25040, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_wcss_dbg_ifc_nts_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_tsctr_div2_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_qdss_tsctr_div2_clk = { > + .halt_reg = 0x2d044, > + .clkr = { > + .enable_reg = 0x2d044, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_tsctr_div2_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_tsctr_div2_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_uniphy_sys_clk_src[] = { > + F(24000000, P_XO, 1, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 uniphy_sys_clk_src = { > + .cmd_rcgr = 0x17090, > + .freq_tbl = ftbl_uniphy_sys_clk_src, > + .mnd_width = 8, > + .hid_width = 5, > + .parent_map = gcc_xo_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "uniphy_sys_clk_src", > + .parent_data = gcc_xo_data, > + .num_parents = ARRAY_SIZE(gcc_xo_data), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_rcg2 nss_ts_clk_src = { > + .cmd_rcgr = 0x17088, > + .freq_tbl = ftbl_uniphy_sys_clk_src, > + .mnd_width = 8, > + .hid_width = 5, > + .parent_map = gcc_xo_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "nss_ts_clk_src", > + .parent_data = gcc_xo_data, > + .num_parents = ARRAY_SIZE(gcc_xo_data), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_qdss_ts_clk = { > + .halt_reg = 0x2d078, > + .clkr = { > + .enable_reg = 0x2d078, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_ts_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &nss_ts_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_fixed_factor qdss_dap_sync_clk_src = { > + .mult = 1, > + .div = 4, > + .hw.init = &(struct clk_init_data) { > + .name = "qdss_dap_sync_clk_src", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_tsctr_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .ops = &clk_fixed_factor_ops, > + }, > +}; > + > +static struct clk_branch gcc_qdss_tsctr_div4_clk = { > + .halt_reg = 0x2d04c, > + .clkr = { > + .enable_reg = 0x2d04c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_tsctr_div4_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_dap_sync_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_fixed_factor qdss_tsctr_div8_clk_src = { > + .mult = 1, > + .div = 8, > + .hw.init = &(struct clk_init_data) { > + .name = "qdss_tsctr_div8_clk_src", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_tsctr_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .ops = &clk_fixed_factor_ops, > + }, > +}; > + > +static struct clk_branch gcc_nss_ts_clk = { > + .halt_reg = 0x17018, > + .clkr = { > + .enable_reg = 0x17018, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nss_ts_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &nss_ts_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_qdss_tsctr_div8_clk = { > + .halt_reg = 0x2d050, > + .clkr = { > + .enable_reg = 0x2d050, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_tsctr_div8_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_tsctr_div8_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_fixed_factor qdss_tsctr_div16_clk_src = { > + .mult = 1, > + .div = 16, > + .hw.init = &(struct clk_init_data) { > + .name = "qdss_tsctr_div16_clk_src", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_tsctr_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .ops = &clk_fixed_factor_ops, > + }, > +}; > + > +static struct clk_branch gcc_qdss_tsctr_div16_clk = { > + .halt_reg = 0x2d054, > + .clkr = { > + .enable_reg = 0x2d054, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_tsctr_div16_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_tsctr_div16_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_q6ss_pclkdbg_clk = { > + .halt_reg = 0x25024, > + .clkr = { > + .enable_reg = 0x25024, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_q6ss_pclkdbg_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_dap_sync_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_q6ss_trig_clk = { > + .halt_reg = 0x25068, > + .clkr = { > + .enable_reg = 0x25068, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_q6ss_trig_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_dap_sync_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_wcss_dbg_ifc_apb_clk = { > + .halt_reg = 0x25038, > + .clkr = { > + .enable_reg = 0x25038, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_wcss_dbg_ifc_apb_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_dap_sync_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_wcss_dbg_ifc_dapbus_clk = { > + .halt_reg = 0x25044, > + .clkr = { > + .enable_reg = 0x25044, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_wcss_dbg_ifc_dapbus_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_dap_sync_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_qdss_dap_clk = { > + .halt_reg = 0x2d058, > + .clkr = { > + .enable_reg = 0x2d058, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_dap_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_dap_sync_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_qdss_apb2jtag_clk = { > + .halt_reg = 0x2d05c, > + .clkr = { > + .enable_reg = 0x2d05c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_apb2jtag_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_dap_sync_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_fixed_factor qdss_tsctr_div3_clk_src = { > + .mult = 1, > + .div = 3, > + .hw.init = &(struct clk_init_data) { > + .name = "qdss_tsctr_div3_clk_src", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_tsctr_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .ops = &clk_fixed_factor_ops, > + }, > +}; > + > +static struct clk_branch gcc_qdss_tsctr_div3_clk = { > + .halt_reg = 0x2d048, > + .clkr = { > + .enable_reg = 0x2d048, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_qdss_tsctr_div3_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &qdss_tsctr_div3_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_qpic_io_macro_clk_src[] = { > + F(24000000, P_XO, 1, 0, 0), > + F(100000000, P_GPLL0, 8, 0, 0), > + F(200000000, P_GPLL0, 4, 0, 0), > + F(320000000, P_GPLL0, 2.5, 0, 0), > + F(400000000, P_GPLL0, 2, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 qpic_io_macro_clk_src = { > + .cmd_rcgr = 0x32004, > + .freq_tbl = ftbl_qpic_io_macro_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_gpll2_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "qpic_io_macro_clk_src", > + .parent_data = gcc_xo_gpll0_gpll2, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll2), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_qpic_io_macro_clk = { > + .halt_reg = 0x3200c, > + .clkr = { > + .enable_reg = 0x3200c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data){ > + .name = "gcc_qpic_io_macro_clk", > + .parent_hws = (const struct clk_hw *[]){ > + &qpic_io_macro_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_q6_axi_clk_src[] = { > + F(533333333, P_GPLL0, 1.5, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 q6_axi_clk_src = { > + .cmd_rcgr = 0x25004, > + .freq_tbl = ftbl_q6_axi_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_gpll2_gpll4_pi_sleep_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "q6_axi_clk_src", > + .parent_data = gcc_xo_gpll0_gpll2_gpll4_pi_sleep, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll2_gpll4_pi_sleep), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_q6_axim_clk = { > + .halt_reg = 0x2500c, > + .clkr = { > + .enable_reg = 0x2500c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_q6_axim_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &q6_axi_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_wcss_q6_tbu_clk = { > + .halt_reg = 0x12050, > + .halt_check = BRANCH_HALT_DELAY, > + .clkr = { > + .enable_reg = 0xb00c, > + .enable_mask = BIT(6), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_wcss_q6_tbu_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &q6_axi_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_mem_noc_q6_axi_clk = { > + .halt_reg = 0x19010, > + .clkr = { > + .enable_reg = 0x19010, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_mem_noc_q6_axi_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &q6_axi_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_q6_axim2_clk_src[] = { > + F(342857143, P_GPLL4, 3.5, 0, 0), > + { } > +}; > + > +static const struct parent_map gcc_xo_gpll0_gpll4_bias_pll_ubinc_clk_map[] = { > + { P_XO, 0 }, > + { P_GPLL0, 1 }, > + { P_GPLL4, 2 }, > + { P_BIAS_PLL_UBI_NC_CLK, 4 }, > +}; > + > +static struct clk_rcg2 q6_axim2_clk_src = { > + .cmd_rcgr = 0x25028, > + .freq_tbl = ftbl_q6_axim2_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_gpll4_bias_pll_ubinc_clk_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "q6_axim2_clk_src", > + .parent_data = gcc_xo_gpll0_gpll4_bias_pll_ubi_nc_clk, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll4_bias_pll_ubi_nc_clk), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static const struct freq_tbl ftbl_nssnoc_memnoc_bfdcd_clk_src[] = { > + F(533333333, P_GPLL0, 1.5, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 nssnoc_memnoc_bfdcd_clk_src = { > + .cmd_rcgr = 0x17004, > + .freq_tbl = ftbl_nssnoc_memnoc_bfdcd_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_gpll0_aux_gpll2_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "nssnoc_memnoc_bfdcd_clk_src", > + .parent_data = gcc_xo_gpll0_gpll0_aux_gpll2, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_aux_gpll2), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_nssnoc_memnoc_clk = { > + .halt_reg = 0x17024, > + .clkr = { > + .enable_reg = 0x17024, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nssnoc_memnoc_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &nssnoc_memnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_nssnoc_mem_noc_1_clk = { > + .halt_reg = 0x17084, > + .clkr = { > + .enable_reg = 0x17084, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nssnoc_mem_noc_1_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &nssnoc_memnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_nss_tbu_clk = { > + .halt_reg = 0x12040, > + .clkr = { > + .enable_reg = 0xb00c, > + .enable_mask = BIT(4), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nss_tbu_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &nssnoc_memnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_mem_noc_nssnoc_clk = { > + .halt_reg = 0x19014, > + .clkr = { > + .enable_reg = 0x19014, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_mem_noc_nssnoc_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &nssnoc_memnoc_bfdcd_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_lpass_axim_clk_src[] = { > + F(133333333, P_GPLL0, 6, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 lpass_axim_clk_src = { > + .cmd_rcgr = 0x2700c, > + .freq_tbl = ftbl_lpass_axim_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "lpass_axim_clk_src", > + .parent_data = gcc_xo_gpll0, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_rcg2 lpass_sway_clk_src = { > + .cmd_rcgr = 0x27004, > + .freq_tbl = ftbl_lpass_axim_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "lpass_sway_clk_src", > + .parent_data = gcc_xo_gpll0, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static const struct freq_tbl ftbl_adss_pwm_clk_src[] = { > + F(24000000, P_XO, 1, 0, 0), > + F(100000000, P_GPLL0, 8, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 adss_pwm_clk_src = { > + .cmd_rcgr = 0x1c004, > + .freq_tbl = ftbl_adss_pwm_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "adss_pwm_clk_src", > + .parent_data = gcc_xo_gpll0, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_adss_pwm_clk = { > + .halt_reg = 0x1c00c, > + .clkr = { > + .enable_reg = 0x1c00c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_adss_pwm_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &adss_pwm_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static const struct freq_tbl ftbl_gp1_clk_src[] = { > + F(24000000, P_XO, 1, 0, 0), > + F(200000000, P_GPLL0, 4, 0, 0), > + { } > +}; > + > +static struct clk_rcg2 gp1_clk_src = { > + .cmd_rcgr = 0x8004, > + .freq_tbl = ftbl_gp1_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_gpll0_sleep_clk_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "gp1_clk_src", > + .parent_data = gcc_xo_gpll0_gpll0_sleep_clk, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_sleep_clk), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_rcg2 gp2_clk_src = { > + .cmd_rcgr = 0x9004, > + .freq_tbl = ftbl_gp1_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_gpll0_sleep_clk_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "gp2_clk_src", > + .parent_data = gcc_xo_gpll0_gpll0_sleep_clk, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_sleep_clk), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_rcg2 gp3_clk_src = { > + .cmd_rcgr = 0xa004, > + .freq_tbl = ftbl_gp1_clk_src, > + .hid_width = 5, > + .parent_map = gcc_xo_gpll0_gpll0_sleep_clk_map, > + .clkr.hw.init = &(struct clk_init_data) { > + .name = "gp3_clk_src", > + .parent_data = gcc_xo_gpll0_gpll0_sleep_clk, > + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_sleep_clk), > + .ops = &clk_rcg2_ops, > + }, > +}; > + > +static struct clk_branch gcc_xo_clk_src = { > + .halt_reg = 0x34004, > + .clkr = { > + .enable_reg = 0x34004, > + .enable_mask = BIT(1), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_xo_clk_src", > + .parent_data = gcc_xo_data, > + .num_parents = ARRAY_SIZE(gcc_xo_data), > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_nssnoc_xo_dcd_clk = { > + .halt_reg = 0x17074, > + .clkr = { > + .enable_reg = 0x17074, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nssnoc_xo_dcd_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &gcc_xo_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_xo_clk = { > + .halt_reg = 0x34018, > + .clkr = { > + .enable_reg = 0x34018, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_xo_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &gcc_xo_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_uniphy0_sys_clk = { > + .halt_reg = 0x17048, > + .clkr = { > + .enable_reg = 0x17048, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_uniphy0_sys_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &uniphy_sys_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_uniphy1_sys_clk = { > + .halt_reg = 0x17058, > + .clkr = { > + .enable_reg = 0x17058, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_uniphy1_sys_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &uniphy_sys_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_uniphy2_sys_clk = { > + .halt_reg = 0x17068, > + .clkr = { > + .enable_reg = 0x17068, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_uniphy2_sys_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &uniphy_sys_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_cmn_12gpll_sys_clk = { > + .halt_reg = 0x3a008, > + .clkr = { > + .enable_reg = 0x3a008, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_cmn_12gpll_sys_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &uniphy_sys_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_fixed_factor gcc_xo_div4_clk_src = { > + .mult = 1, > + .div = 4, > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_xo_div4_clk_src", > + .parent_hws = (const struct clk_hw *[]) { > + &gcc_xo_clk_src.clkr.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_fixed_factor_ops, > + }, > +}; > + > +static struct clk_branch gcc_nssnoc_qosgen_ref_clk = { > + .halt_reg = 0x1701c, > + .clkr = { > + .enable_reg = 0x1701c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nssnoc_qosgen_ref_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &gcc_xo_div4_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_nssnoc_timeout_ref_clk = { > + .halt_reg = 0x17020, > + .clkr = { > + .enable_reg = 0x17020, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_nssnoc_timeout_ref_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &gcc_xo_div4_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_branch gcc_xo_div4_clk = { > + .halt_reg = 0x3401c, > + .clkr = { > + .enable_reg = 0x3401c, > + .enable_mask = BIT(0), > + .hw.init = &(struct clk_init_data) { > + .name = "gcc_xo_div4_clk", > + .parent_hws = (const struct clk_hw *[]) { > + &gcc_xo_div4_clk_src.hw > + }, > + .num_parents = 1, > + .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL, > + .ops = &clk_branch2_ops, > + }, > + }, > +}; > + > +static struct clk_hw *gcc_ipq9574_hws[] = { > + &gpll0_out_main_div2.hw, > + &gcc_xo_div4_clk_src.hw, > + &qdss_dap_sync_clk_src.hw, > + &qdss_tsctr_div2_clk_src.hw, > + &qdss_tsctr_div8_clk_src.hw, > + &qdss_tsctr_div16_clk_src.hw, > + &qdss_tsctr_div3_clk_src.hw, > + &gcc_eud_at_div_clk_src.hw, > +}; > + > +static struct clk_regmap *gcc_ipq9574_clks[] = { > + [GPLL0_MAIN] = &gpll0_main.clkr, > + [GPLL0] = &gpll0.clkr, > + [GPLL4_MAIN] = &gpll4_main.clkr, > + [GPLL4] = &gpll4.clkr, > + [GPLL2_MAIN] = &gpll2_main.clkr, > + [GPLL2] = &gpll2.clkr, > + [GCC_SLEEP_CLK_SRC] = &gcc_sleep_clk_src.clkr, > + [APSS_AHB_CLK_SRC] = &apss_ahb_clk_src.clkr, > + [APSS_AXI_CLK_SRC] = &apss_axi_clk_src.clkr, > + [BLSP1_QUP1_I2C_APPS_CLK_SRC] = &blsp1_qup1_i2c_apps_clk_src.clkr, > + [BLSP1_QUP1_SPI_APPS_CLK_SRC] = &blsp1_qup1_spi_apps_clk_src.clkr, > + [BLSP1_QUP2_I2C_APPS_CLK_SRC] = &blsp1_qup2_i2c_apps_clk_src.clkr, > + [BLSP1_QUP2_SPI_APPS_CLK_SRC] = &blsp1_qup2_spi_apps_clk_src.clkr, > + [BLSP1_QUP3_I2C_APPS_CLK_SRC] = &blsp1_qup3_i2c_apps_clk_src.clkr, > + [BLSP1_QUP3_SPI_APPS_CLK_SRC] = &blsp1_qup3_spi_apps_clk_src.clkr, > + [BLSP1_QUP4_I2C_APPS_CLK_SRC] = &blsp1_qup4_i2c_apps_clk_src.clkr, > + [BLSP1_QUP4_SPI_APPS_CLK_SRC] = &blsp1_qup4_spi_apps_clk_src.clkr, > + [BLSP1_QUP5_I2C_APPS_CLK_SRC] = &blsp1_qup5_i2c_apps_clk_src.clkr, > + [BLSP1_QUP5_SPI_APPS_CLK_SRC] = &blsp1_qup5_spi_apps_clk_src.clkr, > + [BLSP1_QUP6_I2C_APPS_CLK_SRC] = &blsp1_qup6_i2c_apps_clk_src.clkr, > + [BLSP1_QUP6_SPI_APPS_CLK_SRC] = &blsp1_qup6_spi_apps_clk_src.clkr, > + [BLSP1_UART1_APPS_CLK_SRC] = &blsp1_uart1_apps_clk_src.clkr, > + [BLSP1_UART2_APPS_CLK_SRC] = &blsp1_uart2_apps_clk_src.clkr, > + [BLSP1_UART3_APPS_CLK_SRC] = &blsp1_uart3_apps_clk_src.clkr, > + [BLSP1_UART4_APPS_CLK_SRC] = &blsp1_uart4_apps_clk_src.clkr, > + [BLSP1_UART5_APPS_CLK_SRC] = &blsp1_uart5_apps_clk_src.clkr, > + [BLSP1_UART6_APPS_CLK_SRC] = &blsp1_uart6_apps_clk_src.clkr, > + [GCC_APSS_AHB_CLK] = &gcc_apss_ahb_clk.clkr, > + [GCC_APSS_AXI_CLK] = &gcc_apss_axi_clk.clkr, > + [GCC_BLSP1_QUP1_I2C_APPS_CLK] = &gcc_blsp1_qup1_i2c_apps_clk.clkr, > + [GCC_BLSP1_QUP1_SPI_APPS_CLK] = &gcc_blsp1_qup1_spi_apps_clk.clkr, > + [GCC_BLSP1_QUP2_I2C_APPS_CLK] = &gcc_blsp1_qup2_i2c_apps_clk.clkr, > + [GCC_BLSP1_QUP2_SPI_APPS_CLK] = &gcc_blsp1_qup2_spi_apps_clk.clkr, > + [GCC_BLSP1_QUP3_I2C_APPS_CLK] = &gcc_blsp1_qup3_i2c_apps_clk.clkr, > + [GCC_BLSP1_QUP3_SPI_APPS_CLK] = &gcc_blsp1_qup3_spi_apps_clk.clkr, > + [GCC_BLSP1_QUP4_I2C_APPS_CLK] = &gcc_blsp1_qup4_i2c_apps_clk.clkr, > + [GCC_BLSP1_QUP4_SPI_APPS_CLK] = &gcc_blsp1_qup4_spi_apps_clk.clkr, > + [GCC_BLSP1_QUP5_I2C_APPS_CLK] = &gcc_blsp1_qup5_i2c_apps_clk.clkr, > + [GCC_BLSP1_QUP5_SPI_APPS_CLK] = &gcc_blsp1_qup5_spi_apps_clk.clkr, > + [GCC_BLSP1_QUP6_I2C_APPS_CLK] = &gcc_blsp1_qup6_i2c_apps_clk.clkr, > + [GCC_BLSP1_QUP6_SPI_APPS_CLK] = &gcc_blsp1_qup6_spi_apps_clk.clkr, > + [GCC_BLSP1_UART1_APPS_CLK] = &gcc_blsp1_uart1_apps_clk.clkr, > + [GCC_BLSP1_UART2_APPS_CLK] = &gcc_blsp1_uart2_apps_clk.clkr, > + [GCC_BLSP1_UART3_APPS_CLK] = &gcc_blsp1_uart3_apps_clk.clkr, > + [GCC_BLSP1_UART4_APPS_CLK] = &gcc_blsp1_uart4_apps_clk.clkr, > + [GCC_BLSP1_UART5_APPS_CLK] = &gcc_blsp1_uart5_apps_clk.clkr, > + [GCC_BLSP1_UART6_APPS_CLK] = &gcc_blsp1_uart6_apps_clk.clkr, > + [PCIE0_AXI_M_CLK_SRC] = &pcie0_axi_m_clk_src.clkr, > + [GCC_PCIE0_AXI_M_CLK] = &gcc_pcie0_axi_m_clk.clkr, > + [PCIE1_AXI_M_CLK_SRC] = &pcie1_axi_m_clk_src.clkr, > + [GCC_PCIE1_AXI_M_CLK] = &gcc_pcie1_axi_m_clk.clkr, > + [PCIE2_AXI_M_CLK_SRC] = &pcie2_axi_m_clk_src.clkr, > + [GCC_PCIE2_AXI_M_CLK] = &gcc_pcie2_axi_m_clk.clkr, > + [PCIE3_AXI_M_CLK_SRC] = &pcie3_axi_m_clk_src.clkr, > + [GCC_PCIE3_AXI_M_CLK] = &gcc_pcie3_axi_m_clk.clkr, > + [PCIE0_AXI_S_CLK_SRC] = &pcie0_axi_s_clk_src.clkr, > + [GCC_PCIE0_AXI_S_BRIDGE_CLK] = &gcc_pcie0_axi_s_bridge_clk.clkr, > + [GCC_PCIE0_AXI_S_CLK] = &gcc_pcie0_axi_s_clk.clkr, > + [PCIE1_AXI_S_CLK_SRC] = &pcie1_axi_s_clk_src.clkr, > + [GCC_PCIE1_AXI_S_BRIDGE_CLK] = &gcc_pcie1_axi_s_bridge_clk.clkr, > + [GCC_PCIE1_AXI_S_CLK] = &gcc_pcie1_axi_s_clk.clkr, > + [PCIE2_AXI_S_CLK_SRC] = &pcie2_axi_s_clk_src.clkr, > + [GCC_PCIE2_AXI_S_BRIDGE_CLK] = &gcc_pcie2_axi_s_bridge_clk.clkr, > + [GCC_PCIE2_AXI_S_CLK] = &gcc_pcie2_axi_s_clk.clkr, > + [PCIE3_AXI_S_CLK_SRC] = &pcie3_axi_s_clk_src.clkr, > + [GCC_PCIE3_AXI_S_BRIDGE_CLK] = &gcc_pcie3_axi_s_bridge_clk.clkr, > + [GCC_PCIE3_AXI_S_CLK] = &gcc_pcie3_axi_s_clk.clkr, > + [PCIE0_PIPE_CLK_SRC] = &pcie0_pipe_clk_src.clkr, > + [PCIE1_PIPE_CLK_SRC] = &pcie1_pipe_clk_src.clkr, > + [PCIE2_PIPE_CLK_SRC] = &pcie2_pipe_clk_src.clkr, > + [PCIE3_PIPE_CLK_SRC] = &pcie3_pipe_clk_src.clkr, > + [PCIE_AUX_CLK_SRC] = &pcie_aux_clk_src.clkr, > + [GCC_PCIE0_AUX_CLK] = &gcc_pcie0_aux_clk.clkr, > + [GCC_PCIE1_AUX_CLK] = &gcc_pcie1_aux_clk.clkr, > + [GCC_PCIE2_AUX_CLK] = &gcc_pcie2_aux_clk.clkr, > + [GCC_PCIE3_AUX_CLK] = &gcc_pcie3_aux_clk.clkr, > + [PCIE0_RCHNG_CLK_SRC] = &pcie0_rchng_clk_src.clkr, > + [GCC_PCIE0_RCHNG_CLK] = &gcc_pcie0_rchng_clk.clkr, > + [PCIE1_RCHNG_CLK_SRC] = &pcie1_rchng_clk_src.clkr, > + [GCC_PCIE1_RCHNG_CLK] = &gcc_pcie1_rchng_clk.clkr, > + [PCIE2_RCHNG_CLK_SRC] = &pcie2_rchng_clk_src.clkr, > + [GCC_PCIE2_RCHNG_CLK] = &gcc_pcie2_rchng_clk.clkr, > + [PCIE3_RCHNG_CLK_SRC] = &pcie3_rchng_clk_src.clkr, > + [GCC_PCIE3_RCHNG_CLK] = &gcc_pcie3_rchng_clk.clkr, > + [GCC_PCIE0_AHB_CLK] = &gcc_pcie0_ahb_clk.clkr, > + [GCC_PCIE1_AHB_CLK] = &gcc_pcie1_ahb_clk.clkr, > + [GCC_PCIE2_AHB_CLK] = &gcc_pcie2_ahb_clk.clkr, > + [GCC_PCIE3_AHB_CLK] = &gcc_pcie3_ahb_clk.clkr, > + [USB0_AUX_CLK_SRC] = &usb0_aux_clk_src.clkr, > + [GCC_USB0_AUX_CLK] = &gcc_usb0_aux_clk.clkr, > + [USB0_MASTER_CLK_SRC] = &usb0_master_clk_src.clkr, > + [GCC_USB0_MASTER_CLK] = &gcc_usb0_master_clk.clkr, > + [GCC_SNOC_USB_CLK] = &gcc_snoc_usb_clk.clkr, > + [GCC_ANOC_USB_AXI_CLK] = &gcc_anoc_usb_axi_clk.clkr, > + [USB0_MOCK_UTMI_CLK_SRC] = &usb0_mock_utmi_clk_src.clkr, > + [USB0_MOCK_UTMI_DIV_CLK_SRC] = &usb0_mock_utmi_div_clk_src.clkr, > + [GCC_USB0_MOCK_UTMI_CLK] = &gcc_usb0_mock_utmi_clk.clkr, > + [USB0_PIPE_CLK_SRC] = &usb0_pipe_clk_src.clkr, > + [GCC_USB0_PHY_CFG_AHB_CLK] = &gcc_usb0_phy_cfg_ahb_clk.clkr, > + [SDCC1_APPS_CLK_SRC] = &sdcc1_apps_clk_src.clkr, > + [GCC_SDCC1_APPS_CLK] = &gcc_sdcc1_apps_clk.clkr, > + [SDCC1_ICE_CORE_CLK_SRC] = &sdcc1_ice_core_clk_src.clkr, > + [GCC_SDCC1_ICE_CORE_CLK] = &gcc_sdcc1_ice_core_clk.clkr, > + [GCC_SDCC1_AHB_CLK] = &gcc_sdcc1_ahb_clk.clkr, > + [PCNOC_BFDCD_CLK_SRC] = &pcnoc_bfdcd_clk_src.clkr, > + [GCC_NSSCFG_CLK] = &gcc_nsscfg_clk.clkr, > + [GCC_NSSNOC_NSSCC_CLK] = &gcc_nssnoc_nsscc_clk.clkr, > + [GCC_NSSCC_CLK] = &gcc_nsscc_clk.clkr, > + [GCC_NSSNOC_PCNOC_1_CLK] = &gcc_nssnoc_pcnoc_1_clk.clkr, > + [GCC_QDSS_DAP_AHB_CLK] = &gcc_qdss_dap_ahb_clk.clkr, > + [GCC_QDSS_CFG_AHB_CLK] = &gcc_qdss_cfg_ahb_clk.clkr, > + [GCC_QPIC_AHB_CLK] = &gcc_qpic_ahb_clk.clkr, > + [GCC_QPIC_CLK] = &gcc_qpic_clk.clkr, > + [GCC_BLSP1_AHB_CLK] = &gcc_blsp1_ahb_clk.clkr, > + [GCC_MDIO_AHB_CLK] = &gcc_mdio_ahb_clk.clkr, > + [GCC_PRNG_AHB_CLK] = &gcc_prng_ahb_clk.clkr, > + [GCC_UNIPHY0_AHB_CLK] = &gcc_uniphy0_ahb_clk.clkr, > + [GCC_UNIPHY1_AHB_CLK] = &gcc_uniphy1_ahb_clk.clkr, > + [GCC_UNIPHY2_AHB_CLK] = &gcc_uniphy2_ahb_clk.clkr, > + [GCC_CMN_12GPLL_AHB_CLK] = &gcc_cmn_12gpll_ahb_clk.clkr, > + [GCC_CMN_12GPLL_APU_CLK] = &gcc_cmn_12gpll_apu_clk.clkr, > + [SYSTEM_NOC_BFDCD_CLK_SRC] = &system_noc_bfdcd_clk_src.clkr, > + [GCC_NSSNOC_SNOC_CLK] = &gcc_nssnoc_snoc_clk.clkr, > + [GCC_NSSNOC_SNOC_1_CLK] = &gcc_nssnoc_snoc_1_clk.clkr, > + [GCC_QDSS_ETR_USB_CLK] = &gcc_qdss_etr_usb_clk.clkr, > + [WCSS_AHB_CLK_SRC] = &wcss_ahb_clk_src.clkr, > + [GCC_Q6_AHB_CLK] = &gcc_q6_ahb_clk.clkr, > + [GCC_Q6_AHB_S_CLK] = &gcc_q6_ahb_s_clk.clkr, > + [GCC_WCSS_ECAHB_CLK] = &gcc_wcss_ecahb_clk.clkr, > + [GCC_WCSS_ACMT_CLK] = &gcc_wcss_acmt_clk.clkr, > + [GCC_SYS_NOC_WCSS_AHB_CLK] = &gcc_sys_noc_wcss_ahb_clk.clkr, > + [WCSS_AXI_M_CLK_SRC] = &wcss_axi_m_clk_src.clkr, > + [GCC_ANOC_WCSS_AXI_M_CLK] = &gcc_anoc_wcss_axi_m_clk.clkr, > + [QDSS_AT_CLK_SRC] = &qdss_at_clk_src.clkr, > + [GCC_Q6SS_ATBM_CLK] = &gcc_q6ss_atbm_clk.clkr, > + [GCC_WCSS_DBG_IFC_ATB_CLK] = &gcc_wcss_dbg_ifc_atb_clk.clkr, > + [GCC_NSSNOC_ATB_CLK] = &gcc_nssnoc_atb_clk.clkr, > + [GCC_QDSS_AT_CLK] = &gcc_qdss_at_clk.clkr, > + [GCC_SYS_NOC_AT_CLK] = &gcc_sys_noc_at_clk.clkr, > + [GCC_PCNOC_AT_CLK] = &gcc_pcnoc_at_clk.clkr, > + [GCC_USB0_EUD_AT_CLK] = &gcc_usb0_eud_at_clk.clkr, > + [GCC_QDSS_EUD_AT_CLK] = &gcc_qdss_eud_at_clk.clkr, > + [QDSS_STM_CLK_SRC] = &qdss_stm_clk_src.clkr, > + [GCC_QDSS_STM_CLK] = &gcc_qdss_stm_clk.clkr, > + [GCC_SYS_NOC_QDSS_STM_AXI_CLK] = &gcc_sys_noc_qdss_stm_axi_clk.clkr, > + [QDSS_TRACECLKIN_CLK_SRC] = &qdss_traceclkin_clk_src.clkr, > + [GCC_QDSS_TRACECLKIN_CLK] = &gcc_qdss_traceclkin_clk.clkr, > + [QDSS_TSCTR_CLK_SRC] = &qdss_tsctr_clk_src.clkr, > + [GCC_Q6_TSCTR_1TO2_CLK] = &gcc_q6_tsctr_1to2_clk.clkr, > + [GCC_WCSS_DBG_IFC_NTS_CLK] = &gcc_wcss_dbg_ifc_nts_clk.clkr, > + [GCC_QDSS_TSCTR_DIV2_CLK] = &gcc_qdss_tsctr_div2_clk.clkr, > + [GCC_QDSS_TS_CLK] = &gcc_qdss_ts_clk.clkr, > + [GCC_QDSS_TSCTR_DIV4_CLK] = &gcc_qdss_tsctr_div4_clk.clkr, > + [GCC_NSS_TS_CLK] = &gcc_nss_ts_clk.clkr, > + [GCC_QDSS_TSCTR_DIV8_CLK] = &gcc_qdss_tsctr_div8_clk.clkr, > + [GCC_QDSS_TSCTR_DIV16_CLK] = &gcc_qdss_tsctr_div16_clk.clkr, > + [GCC_Q6SS_PCLKDBG_CLK] = &gcc_q6ss_pclkdbg_clk.clkr, > + [GCC_Q6SS_TRIG_CLK] = &gcc_q6ss_trig_clk.clkr, > + [GCC_WCSS_DBG_IFC_APB_CLK] = &gcc_wcss_dbg_ifc_apb_clk.clkr, > + [GCC_WCSS_DBG_IFC_DAPBUS_CLK] = &gcc_wcss_dbg_ifc_dapbus_clk.clkr, > + [GCC_QDSS_DAP_CLK] = &gcc_qdss_dap_clk.clkr, > + [GCC_QDSS_APB2JTAG_CLK] = &gcc_qdss_apb2jtag_clk.clkr, > + [GCC_QDSS_TSCTR_DIV3_CLK] = &gcc_qdss_tsctr_div3_clk.clkr, > + [QPIC_IO_MACRO_CLK_SRC] = &qpic_io_macro_clk_src.clkr, > + [GCC_QPIC_IO_MACRO_CLK] = &gcc_qpic_io_macro_clk.clkr, > + [Q6_AXI_CLK_SRC] = &q6_axi_clk_src.clkr, > + [GCC_Q6_AXIM_CLK] = &gcc_q6_axim_clk.clkr, > + [GCC_WCSS_Q6_TBU_CLK] = &gcc_wcss_q6_tbu_clk.clkr, > + [GCC_MEM_NOC_Q6_AXI_CLK] = &gcc_mem_noc_q6_axi_clk.clkr, > + [Q6_AXIM2_CLK_SRC] = &q6_axim2_clk_src.clkr, > + [NSSNOC_MEMNOC_BFDCD_CLK_SRC] = &nssnoc_memnoc_bfdcd_clk_src.clkr, > + [GCC_NSSNOC_MEMNOC_CLK] = &gcc_nssnoc_memnoc_clk.clkr, > + [GCC_NSSNOC_MEM_NOC_1_CLK] = &gcc_nssnoc_mem_noc_1_clk.clkr, > + [GCC_NSS_TBU_CLK] = &gcc_nss_tbu_clk.clkr, > + [GCC_MEM_NOC_NSSNOC_CLK] = &gcc_mem_noc_nssnoc_clk.clkr, > + [LPASS_AXIM_CLK_SRC] = &lpass_axim_clk_src.clkr, > + [LPASS_SWAY_CLK_SRC] = &lpass_sway_clk_src.clkr, > + [ADSS_PWM_CLK_SRC] = &adss_pwm_clk_src.clkr, > + [GCC_ADSS_PWM_CLK] = &gcc_adss_pwm_clk.clkr, > + [GP1_CLK_SRC] = &gp1_clk_src.clkr, > + [GP2_CLK_SRC] = &gp2_clk_src.clkr, > + [GP3_CLK_SRC] = &gp3_clk_src.clkr, > + [GCC_XO_CLK_SRC] = &gcc_xo_clk_src.clkr, > + [GCC_NSSNOC_XO_DCD_CLK] = &gcc_nssnoc_xo_dcd_clk.clkr, > + [GCC_XO_CLK] = &gcc_xo_clk.clkr, > + [GCC_NSSNOC_QOSGEN_REF_CLK] = &gcc_nssnoc_qosgen_ref_clk.clkr, > + [GCC_NSSNOC_TIMEOUT_REF_CLK] = &gcc_nssnoc_timeout_ref_clk.clkr, > + [GCC_XO_DIV4_CLK] = &gcc_xo_div4_clk.clkr, > + [GCC_UNIPHY0_SYS_CLK] = &gcc_uniphy0_sys_clk.clkr, > + [GCC_UNIPHY1_SYS_CLK] = &gcc_uniphy1_sys_clk.clkr, > + [GCC_UNIPHY2_SYS_CLK] = &gcc_uniphy2_sys_clk.clkr, > + [GCC_CMN_12GPLL_SYS_CLK] = &gcc_cmn_12gpll_sys_clk.clkr, > + [GCC_Q6SS_BOOT_CLK] = &gcc_q6ss_boot_clk.clkr, > + [UNIPHY_SYS_CLK_SRC] = &uniphy_sys_clk_src.clkr, > + [NSS_TS_CLK_SRC] = &nss_ts_clk_src.clkr, > + [GCC_ANOC_PCIE0_1LANE_M_CLK] = &gcc_anoc_pcie0_1lane_m_clk.clkr, > + [GCC_ANOC_PCIE1_1LANE_M_CLK] = &gcc_anoc_pcie1_1lane_m_clk.clkr, > + [GCC_ANOC_PCIE2_2LANE_M_CLK] = &gcc_anoc_pcie2_2lane_m_clk.clkr, > + [GCC_ANOC_PCIE3_2LANE_M_CLK] = &gcc_anoc_pcie3_2lane_m_clk.clkr, > + [GCC_SNOC_PCIE0_1LANE_S_CLK] = &gcc_snoc_pcie0_1lane_s_clk.clkr, > + [GCC_SNOC_PCIE1_1LANE_S_CLK] = &gcc_snoc_pcie1_1lane_s_clk.clkr, > + [GCC_SNOC_PCIE2_2LANE_S_CLK] = &gcc_snoc_pcie2_2lane_s_clk.clkr, > + [GCC_SNOC_PCIE3_2LANE_S_CLK] = &gcc_snoc_pcie3_2lane_s_clk.clkr, > +}; > + > +static const struct qcom_reset_map gcc_ipq9574_resets[] = { > + [GCC_ADSS_BCR] = { 0x1c000, 0 }, > + [GCC_ANOC0_TBU_BCR] = { 0x1203c, 0 }, > + [GCC_ANOC1_TBU_BCR] = { 0x1204c, 0 }, > + [GCC_ANOC_BCR] = { 0x2e074, 0 }, > + [GCC_APC0_VOLTAGE_DROOP_DETECTOR_BCR] = { 0x38000, 0 }, > + [GCC_APSS_TCU_BCR] = { 0x12014, 0 }, > + [GCC_BLSP1_BCR] = { 0x01000, 0 }, > + [GCC_BLSP1_QUP1_BCR] = { 0x02000, 0 }, > + [GCC_BLSP1_QUP2_BCR] = { 0x03000, 0 }, > + [GCC_BLSP1_QUP3_BCR] = { 0x04000, 0 }, > + [GCC_BLSP1_QUP4_BCR] = { 0x05000, 0 }, > + [GCC_BLSP1_QUP5_BCR] = { 0x06000, 0 }, > + [GCC_BLSP1_QUP6_BCR] = { 0x07000, 0 }, > + [GCC_BLSP1_UART1_BCR] = { 0x02028, 0 }, > + [GCC_BLSP1_UART2_BCR] = { 0x03028, 0 }, > + [GCC_BLSP1_UART3_BCR] = { 0x04028, 0 }, > + [GCC_BLSP1_UART4_BCR] = { 0x05028, 0 }, > + [GCC_BLSP1_UART5_BCR] = { 0x06028, 0 }, > + [GCC_BLSP1_UART6_BCR] = { 0x07028, 0 }, > + [GCC_BOOT_ROM_BCR] = { 0x13028, 0 }, > + [GCC_CMN_BLK_BCR] = { 0x3a000, 0 }, > + [GCC_CMN_BLK_AHB_ARES] = { 0x3a010, 0 }, > + [GCC_CMN_BLK_SYS_ARES] = { 0x3a010, 1 }, > + [GCC_CMN_BLK_APU_ARES] = { 0x3a010, 2 }, > + [GCC_DCC_BCR] = { 0x35000, 0 }, > + [GCC_DDRSS_BCR] = { 0x11000, 0 }, > + [GCC_IMEM_BCR] = { 0x0e000, 0 }, > + [GCC_LPASS_BCR] = { 0x27000, 0 }, > + [GCC_MDIO_BCR] = { 0x1703c, 0 }, > + [GCC_MPM_BCR] = { 0x37000, 0 }, > + [GCC_MSG_RAM_BCR] = { 0x26000, 0 }, > + [GCC_NSS_BCR] = { 0x17000, 0 }, > + [GCC_NSS_TBU_BCR] = { 0x12044, 0 }, > + [GCC_NSSNOC_MEMNOC_1_ARES] = { 0x17038, 13 }, > + [GCC_NSSNOC_PCNOC_1_ARES] = { 0x17038, 12 }, > + [GCC_NSSNOC_SNOC_1_ARES] = { 0x17038, 11 }, > + [GCC_NSSNOC_XO_DCD_ARES] = { 0x17038, 10 }, > + [GCC_NSSNOC_TS_ARES] = { 0x17038, 9 }, > + [GCC_NSSCC_ARES] = { 0x17038, 8 }, > + [GCC_NSSNOC_NSSCC_ARES] = { 0x17038, 7 }, > + [GCC_NSSNOC_ATB_ARES] = { 0x17038, 6 }, > + [GCC_NSSNOC_MEMNOC_ARES] = { 0x17038, 5 }, > + [GCC_NSSNOC_QOSGEN_REF_ARES] = { 0x17038, 4 }, > + [GCC_NSSNOC_SNOC_ARES] = { 0x17038, 3 }, > + [GCC_NSSNOC_TIMEOUT_REF_ARES] = { 0x17038, 2 }, > + [GCC_NSS_CFG_ARES] = { 0x17038, 1 }, > + [GCC_UBI0_DBG_ARES] = { 0x17038, 0 }, > + [GCC_PCIE0PHY_PHY_BCR] = { 0x2805c, 0 }, > + [GCC_PCIE0_AHB_ARES] = { 0x28058, 7 }, > + [GCC_PCIE0_AUX_ARES] = { 0x28058, 6 }, > + [GCC_PCIE0_AXI_M_ARES] = { 0x28058, 5 }, > + [GCC_PCIE0_AXI_M_STICKY_ARES] = { 0x28058, 4 }, > + [GCC_PCIE0_AXI_S_ARES] = { 0x28058, 3 }, > + [GCC_PCIE0_AXI_S_STICKY_ARES] = { 0x28058, 2 }, > + [GCC_PCIE0_CORE_STICKY_ARES] = { 0x28058, 1 }, > + [GCC_PCIE0_PIPE_ARES] = { 0x28058, 0 }, > + [GCC_PCIE1_AHB_ARES] = { 0x29058, 7 }, > + [GCC_PCIE1_AUX_ARES] = { 0x29058, 6 }, > + [GCC_PCIE1_AXI_M_ARES] = { 0x29058, 5 }, > + [GCC_PCIE1_AXI_M_STICKY_ARES] = { 0x29058, 4 }, > + [GCC_PCIE1_AXI_S_ARES] = { 0x29058, 3 }, > + [GCC_PCIE1_AXI_S_STICKY_ARES] = { 0x29058, 2 }, > + [GCC_PCIE1_CORE_STICKY_ARES] = { 0x29058, 1 }, > + [GCC_PCIE1_PIPE_ARES] = { 0x29058, 0 }, > + [GCC_PCIE2_AHB_ARES] = { 0x2a058, 7 }, > + [GCC_PCIE2_AUX_ARES] = { 0x2a058, 6 }, > + [GCC_PCIE2_AXI_M_ARES] = { 0x2a058, 5 }, > + [GCC_PCIE2_AXI_M_STICKY_ARES] = { 0x2a058, 4 }, > + [GCC_PCIE2_AXI_S_ARES] = { 0x2a058, 3 }, > + [GCC_PCIE2_AXI_S_STICKY_ARES] = { 0x2a058, 2 }, > + [GCC_PCIE2_CORE_STICKY_ARES] = { 0x2a058, 1 }, > + [GCC_PCIE2_PIPE_ARES] = { 0x2a058, 0 }, > + [GCC_PCIE3_AHB_ARES] = { 0x2b058, 7 }, > + [GCC_PCIE3_AUX_ARES] = { 0x2b058, 6 }, > + [GCC_PCIE3_AXI_M_ARES] = { 0x2b058, 5 }, > + [GCC_PCIE3_AXI_M_STICKY_ARES] = { 0x2b058, 4 }, > + [GCC_PCIE3_AXI_S_ARES] = { 0x2b058, 3 }, > + [GCC_PCIE3_AXI_S_STICKY_ARES] = { 0x2b058, 2 }, > + [GCC_PCIE3_CORE_STICKY_ARES] = { 0x2b058, 1 }, > + [GCC_PCIE3_PIPE_ARES] = { 0x2b058, 0 }, > + [GCC_PCIE0_BCR] = { 0x28000, 0 }, > + [GCC_PCIE0_LINK_DOWN_BCR] = { 0x28054, 0 }, > + [GCC_PCIE0_PHY_BCR] = { 0x28060, 0 }, > + [GCC_PCIE1_BCR] = { 0x29000, 0 }, > + [GCC_PCIE1_LINK_DOWN_BCR] = { 0x29054, 0 }, > + [GCC_PCIE1_PHY_BCR] = { 0x29060, 0 }, > + [GCC_PCIE1PHY_PHY_BCR] = { 0x2905c, 0 }, > + [GCC_PCIE2_BCR] = { 0x2a000, 0 }, > + [GCC_PCIE2_LINK_DOWN_BCR] = { 0x2a054, 0 }, > + [GCC_PCIE2_PHY_BCR] = { 0x2a060, 0 }, > + [GCC_PCIE2PHY_PHY_BCR] = { 0x2a05c, 0 }, > + [GCC_PCIE3_BCR] = { 0x2b000, 0 }, > + [GCC_PCIE3_LINK_DOWN_BCR] = { 0x2b054, 0 }, > + [GCC_PCIE3PHY_PHY_BCR] = { 0x2b05c, 0 }, > + [GCC_PCIE3_PHY_BCR] = { 0x2b060, 0 }, > + [GCC_PCNOC_BCR] = { 0x31000, 0 }, > + [GCC_PCNOC_BUS_TIMEOUT0_BCR] = { 0x31030, 0 }, > + [GCC_PCNOC_BUS_TIMEOUT1_BCR] = { 0x31038, 0 }, > + [GCC_PCNOC_BUS_TIMEOUT2_BCR] = { 0x31040, 0 }, > + [GCC_PCNOC_BUS_TIMEOUT3_BCR] = { 0x31048, 0 }, > + [GCC_PCNOC_BUS_TIMEOUT4_BCR] = { 0x31050, 0 }, > + [GCC_PCNOC_BUS_TIMEOUT5_BCR] = { 0x31058, 0 }, > + [GCC_PCNOC_BUS_TIMEOUT6_BCR] = { 0x31060, 0 }, > + [GCC_PCNOC_BUS_TIMEOUT7_BCR] = { 0x31068, 0 }, > + [GCC_PCNOC_BUS_TIMEOUT8_BCR] = { 0x31070, 0 }, > + [GCC_PCNOC_BUS_TIMEOUT9_BCR] = { 0x31078, 0 }, > + [GCC_PCNOC_TBU_BCR] = { 0x12034, 0 }, > + [GCC_PRNG_BCR] = { 0x13020, 0 }, > + [GCC_Q6SS_DBG_ARES] = { 0x2506c, 4 }, > + [GCC_Q6_AHB_ARES] = { 0x2506c, 3 }, > + [GCC_Q6_AHB_S_ARES] = { 0x2506c, 2 }, > + [GCC_Q6_AXIM2_ARES] = { 0x2506c, 1 }, > + [GCC_Q6_AXIM_ARES] = { 0x2506c, 0 }, > + [GCC_QDSS_BCR] = { 0x2d000, 0 }, > + [GCC_QPIC_BCR] = { 0x32000, 0 }, > + [GCC_QPIC_AHB_ARES] = { 0x3201c, 1 }, > + [GCC_QPIC_ARES] = { 0x3201c, 0 }, > + [GCC_QUSB2_0_PHY_BCR] = { 0x2c068, 0 }, > + [GCC_RBCPR_BCR] = { 0x39000, 0 }, > + [GCC_RBCPR_MX_BCR] = { 0x39014, 0 }, > + [GCC_SDCC_BCR] = { 0x33000, 0 }, > + [GCC_SEC_CTRL_BCR] = { 0x1a000, 0 }, > + [GCC_SMMU_CFG_BCR] = { 0x1202c, 0 }, > + [GCC_SNOC_BCR] = { 0x2e000, 0 }, > + [GCC_SPDM_BCR] = { 0x36000, 0 }, > + [GCC_TCSR_BCR] = { 0x3d000, 0 }, > + [GCC_TLMM_BCR] = { 0x3e000, 0 }, > + [GCC_TME_BCR] = { 0x10000, 0 }, > + [GCC_UNIPHY0_BCR] = { 0x17044, 0 }, > + [GCC_UNIPHY0_SYS_RESET] = { 0x17050, 0 }, > + [GCC_UNIPHY0_AHB_RESET] = { 0x17050, 1 }, > + [GCC_UNIPHY0_XPCS_RESET] = { 0x17050, 2 }, > + [GCC_UNIPHY1_SYS_RESET] = { 0x17060, 0 }, > + [GCC_UNIPHY1_AHB_RESET] = { 0x17060, 1 }, > + [GCC_UNIPHY1_XPCS_RESET] = { 0x17060, 2 }, > + [GCC_UNIPHY2_SYS_RESET] = { 0x17070, 0 }, > + [GCC_UNIPHY2_AHB_RESET] = { 0x17070, 1 }, > + [GCC_UNIPHY2_XPCS_RESET] = { 0x17070, 2 }, > + [GCC_UNIPHY1_BCR] = { 0x17054, 0 }, > + [GCC_UNIPHY2_BCR] = { 0x17064, 0 }, > + [GCC_USB0_PHY_BCR] = { 0x2c06c, 0 }, > + [GCC_USB3PHY_0_PHY_BCR] = { 0x2c070, 0 }, > + [GCC_USB_BCR] = { 0x2c000, 0 }, > + [GCC_USB_MISC_RESET] = { 0x2c064, 0 }, > + [GCC_WCSSAON_RESET] = { 0x25074, 0 }, > + [GCC_WCSS_ACMT_ARES] = { 0x25070, 5 }, > + [GCC_WCSS_AHB_S_ARES] = { 0x25070, 4 }, > + [GCC_WCSS_AXI_M_ARES] = { 0x25070, 3 }, > + [GCC_WCSS_BCR] = { 0x18004, 0 }, > + [GCC_WCSS_DBG_ARES] = { 0x25070, 2 }, > + [GCC_WCSS_DBG_BDG_ARES] = { 0x25070, 1 }, > + [GCC_WCSS_ECAHB_ARES] = { 0x25070, 0 }, > + [GCC_WCSS_Q6_BCR] = { 0x18000, 0 }, > + [GCC_WCSS_Q6_TBU_BCR] = { 0x12054, 0 }, > +}; > + > +static const struct of_device_id gcc_ipq9574_match_table[] = { > + { .compatible = "qcom,ipq9574-gcc" }, > + { } > +}; > +MODULE_DEVICE_TABLE(of, gcc_ipq9574_match_table); > + > +static const struct regmap_config gcc_ipq9574_regmap_config = { > + .reg_bits = 32, > + .reg_stride = 4, > + .val_bits = 32, > + .max_register = 0x7fffc, > + .fast_io = true, > +}; > + > +static const struct qcom_cc_desc gcc_ipq9574_desc = { > + .config = &gcc_ipq9574_regmap_config, > + .clks = gcc_ipq9574_clks, > + .num_clks = ARRAY_SIZE(gcc_ipq9574_clks), > + .resets = gcc_ipq9574_resets, > + .num_resets = ARRAY_SIZE(gcc_ipq9574_resets), > + .clk_hws = gcc_ipq9574_hws, > + .num_clk_hws = ARRAY_SIZE(gcc_ipq9574_hws), > +}; > + > +static int gcc_ipq9574_probe(struct platform_device *pdev) > +{ > + struct regmap *regmap; > + struct qcom_cc_desc ipq9574_desc = gcc_ipq9574_desc; > + > + regmap = qcom_cc_map(pdev, &ipq9574_desc); > + if (IS_ERR(regmap)) > + return PTR_ERR(regmap); > + > + return qcom_cc_really_probe(pdev, &ipq9574_desc, regmap); > +} > + > +static struct platform_driver gcc_ipq9574_driver = { > + .probe = gcc_ipq9574_probe, > + .driver = { > + .name = "qcom,gcc-ipq9574", > + .of_match_table = gcc_ipq9574_match_table, > + }, > +}; > + > +static int __init gcc_ipq9574_init(void) > +{ > + return platform_driver_register(&gcc_ipq9574_driver); > +} > +core_initcall(gcc_ipq9574_init); > + > +static void __exit gcc_ipq9574_exit(void) > +{ > + platform_driver_unregister(&gcc_ipq9574_driver); > +} > +module_exit(gcc_ipq9574_exit); > + > +MODULE_DESCRIPTION("Qualcomm Technologies, Inc. GCC IPQ9574 Driver"); > +MODULE_LICENSE("GPL");
Thanks for taking time to review the patch! On 1/26/2023 5:17 AM, Konrad Dybcio wrote: > > > On 24.01.2023 15:15, devi priya wrote: >> Add Global Clock Controller (GCC) driver for ipq9574 based devices >> >> Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> >> Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> >> Signed-off-by: devi priya <quic_devipriy@quicinc.com> >> --- >> drivers/clk/qcom/Kconfig | 8 + >> drivers/clk/qcom/Makefile | 1 + >> drivers/clk/qcom/gcc-ipq9574.c | 4301 ++++++++++++++++++++++++++++++++ >> 3 files changed, 4310 insertions(+) >> create mode 100644 drivers/clk/qcom/gcc-ipq9574.c >> >> diff --git a/drivers/clk/qcom/Kconfig b/drivers/clk/qcom/Kconfig >> index 70d43f0a8919..97517d1e3ba4 100644 >> --- a/drivers/clk/qcom/Kconfig >> +++ b/drivers/clk/qcom/Kconfig >> @@ -173,6 +173,14 @@ config IPQ_GCC_8074 >> i2c, USB, SD/eMMC, etc. Select this for the root clock >> of ipq8074. >> >> +config IPQ_GCC_9574 >> + tristate "IPQ9574 Global Clock Controller" >> + help >> + Support for global clock controller on ipq9574 devices. >> + Say Y if you want to use peripheral devices such as UART, SPI, >> + i2c, USB, SD/eMMC, etc. Select this for the root clock >> + of ipq9574. >> + >> config MSM_GCC_8660 >> tristate "MSM8660 Global Clock Controller" >> help >> diff --git a/drivers/clk/qcom/Makefile b/drivers/clk/qcom/Makefile >> index f18c446a97ea..55c6ada326e0 100644 >> --- a/drivers/clk/qcom/Makefile >> +++ b/drivers/clk/qcom/Makefile >> @@ -27,6 +27,7 @@ obj-$(CONFIG_IPQ_GCC_4019) += gcc-ipq4019.o >> obj-$(CONFIG_IPQ_GCC_6018) += gcc-ipq6018.o >> obj-$(CONFIG_IPQ_GCC_806X) += gcc-ipq806x.o >> obj-$(CONFIG_IPQ_GCC_8074) += gcc-ipq8074.o >> +obj-$(CONFIG_IPQ_GCC_9574) += gcc-ipq9574.o >> obj-$(CONFIG_IPQ_LCC_806X) += lcc-ipq806x.o >> obj-$(CONFIG_MDM_GCC_9607) += gcc-mdm9607.o >> obj-$(CONFIG_MDM_GCC_9615) += gcc-mdm9615.o >> diff --git a/drivers/clk/qcom/gcc-ipq9574.c b/drivers/clk/qcom/gcc-ipq9574.c >> new file mode 100644 >> index 000000000000..6b3509e5f90e >> --- /dev/null >> +++ b/drivers/clk/qcom/gcc-ipq9574.c >> @@ -0,0 +1,4301 @@ >> +// SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) >> +/* >> + * Copyright (c) 2023 The Linux Foundation. All rights reserved. >> + */ >> + > [...] > >> +static struct clk_branch gcc_apss_ahb_clk = { >> + .halt_reg = 0x24018, >> + .halt_check = BRANCH_HALT_VOTED, >> + .clkr = { >> + .enable_reg = 0x0b004, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_apss_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &apss_ahb_clk_src.clkr.hw > Wrong indentation, there's quite a few occurences, please > take care of that. Sure, will update >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + > [...] > >> + >> +static struct clk_rcg2 pcnoc_bfdcd_clk_src = { > Doesn't RPM scale the interconnect clocks on this platform? > By the way, it seems rather strange that you did not add > RPM(h) support at all with this series.. > > If it does, it may be worth dropping them as they're pretty > much unnecessary fluff that may fight with the internal RPM > voters for "whose rate is the best rate".. > No, we do not have RPM scaling for interconnect clocks on IPQ platforms. > Konrad >> + .cmd_rcgr = 0x31004, >> + .freq_tbl = ftbl_pcnoc_bfdcd_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "pcnoc_bfdcd_clk_src", >> + .parent_data = gcc_xo_gpll0_gpll0_out_main_div2, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_out_main_div2), >> + .flags = CLK_IS_CRITICAL, >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nsscfg_clk = { >> + .halt_reg = 0x1702c, >> + .clkr = { >> + .enable_reg = 0x1702c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nsscfg_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nssnoc_nsscc_clk = { >> + .halt_reg = 0x17030, >> + .clkr = { >> + .enable_reg = 0x17030, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nssnoc_nsscc_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nsscc_clk = { >> + .halt_reg = 0x17034, >> + .clkr = { >> + .enable_reg = 0x17034, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nsscc_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nssnoc_pcnoc_1_clk = { >> + .halt_reg = 0x17080, >> + .clkr = { >> + .enable_reg = 0x17080, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nssnoc_pcnoc_1_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_dap_ahb_clk = { >> + .halt_reg = 0x2d064, >> + .clkr = { >> + .enable_reg = 0x2d064, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_dap_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_cfg_ahb_clk = { >> + .halt_reg = 0x2d068, >> + .clkr = { >> + .enable_reg = 0x2d068, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_cfg_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qpic_ahb_clk = { >> + .halt_reg = 0x32010, >> + .clkr = { >> + .enable_reg = 0x32010, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qpic_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qpic_clk = { >> + .halt_reg = 0x32014, >> + .clkr = { >> + .enable_reg = 0x32014, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qpic_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_blsp1_ahb_clk = { >> + .halt_reg = 0x01004, >> + .halt_check = BRANCH_HALT_VOTED, >> + .clkr = { >> + .enable_reg = 0x0b004, >> + .enable_mask = BIT(4), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_blsp1_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_mdio_ahb_clk = { >> + .halt_reg = 0x17040, >> + .clkr = { >> + .enable_reg = 0x17040, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_mdio_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_prng_ahb_clk = { >> + .halt_reg = 0x13024, >> + .halt_check = BRANCH_HALT_VOTED, >> + .clkr = { >> + .enable_reg = 0x0b004, >> + .enable_mask = BIT(10), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_prng_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_uniphy0_ahb_clk = { >> + .halt_reg = 0x1704c, >> + .clkr = { >> + .enable_reg = 0x1704c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_uniphy0_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_uniphy1_ahb_clk = { >> + .halt_reg = 0x1705c, >> + .clkr = { >> + .enable_reg = 0x1705c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_uniphy1_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_uniphy2_ahb_clk = { >> + .halt_reg = 0x1706c, >> + .clkr = { >> + .enable_reg = 0x1706c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_uniphy2_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_cmn_12gpll_ahb_clk = { >> + .halt_reg = 0x3a004, >> + .clkr = { >> + .enable_reg = 0x3a004, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_cmn_12gpll_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_cmn_12gpll_apu_clk = { >> + .halt_reg = 0x3a00c, >> + .clkr = { >> + .enable_reg = 0x3a00c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_cmn_12gpll_apu_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_pcie0_ahb_clk = { >> + .halt_reg = 0x28030, >> + .clkr = { >> + .enable_reg = 0x28030, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_pcie0_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_pcie1_ahb_clk = { >> + .halt_reg = 0x29030, >> + .clkr = { >> + .enable_reg = 0x29030, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_pcie1_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_pcie2_ahb_clk = { >> + .halt_reg = 0x2a030, >> + .clkr = { >> + .enable_reg = 0x2a030, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_pcie2_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_pcie3_ahb_clk = { >> + .halt_reg = 0x2b030, >> + .clkr = { >> + .enable_reg = 0x2b030, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_pcie3_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_usb0_phy_cfg_ahb_clk = { >> + .halt_reg = 0x2c05c, >> + .clkr = { >> + .enable_reg = 0x2c05c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_usb0_phy_cfg_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_sdcc1_ahb_clk = { >> + .halt_reg = 0x33034, >> + .clkr = { >> + .enable_reg = 0x33034, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_sdcc1_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &pcnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_system_noc_bfdcd_clk_src[] = { >> + F(24000000, P_XO, 1, 0, 0), >> + F(133333333, P_GPLL0, 6, 0, 0), >> + F(200000000, P_GPLL0, 4, 0, 0), >> + F(342850000, P_GPLL4, 3.5, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 system_noc_bfdcd_clk_src = { >> + .cmd_rcgr = 0x2e004, >> + .freq_tbl = ftbl_system_noc_bfdcd_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_gpll4_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "system_noc_bfdcd_clk_src", >> + .parent_data = gcc_xo_gpll0_gpll4, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll4), >> + .flags = CLK_IS_CRITICAL, >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_q6ss_boot_clk = { >> + .halt_reg = 0x25080, >> + .halt_check = BRANCH_HALT_SKIP, >> + .clkr = { >> + .enable_reg = 0x25080, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_q6ss_boot_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &system_noc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nssnoc_snoc_clk = { >> + .halt_reg = 0x17028, >> + .clkr = { >> + .enable_reg = 0x17028, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nssnoc_snoc_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &system_noc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nssnoc_snoc_1_clk = { >> + .halt_reg = 0x1707c, >> + .clkr = { >> + .enable_reg = 0x1707c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nssnoc_snoc_1_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &system_noc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_etr_usb_clk = { >> + .halt_reg = 0x2d060, >> + .clkr = { >> + .enable_reg = 0x2d060, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_etr_usb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &system_noc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_wcss_ahb_clk_src[] = { >> + F(24000000, P_XO, 1, 0, 0), >> + F(133333333, P_GPLL0, 6, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 wcss_ahb_clk_src = { >> + .cmd_rcgr = 0x25030, >> + .freq_tbl = ftbl_wcss_ahb_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "wcss_ahb_clk_src", >> + .parent_data = gcc_xo_gpll0, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_q6_ahb_clk = { >> + .halt_reg = 0x25014, >> + .clkr = { >> + .enable_reg = 0x25014, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_q6_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &wcss_ahb_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_q6_ahb_s_clk = { >> + .halt_reg = 0x25018, >> + .clkr = { >> + .enable_reg = 0x25018, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_q6_ahb_s_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &wcss_ahb_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_wcss_ecahb_clk = { >> + .halt_reg = 0x25058, >> + .clkr = { >> + .enable_reg = 0x25058, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_wcss_ecahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &wcss_ahb_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_wcss_acmt_clk = { >> + .halt_reg = 0x2505c, >> + .clkr = { >> + .enable_reg = 0x2505c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_wcss_acmt_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &wcss_ahb_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_sys_noc_wcss_ahb_clk = { >> + .halt_reg = 0x2e030, >> + .clkr = { >> + .enable_reg = 0x2e030, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_sys_noc_wcss_ahb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &wcss_ahb_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_wcss_axi_m_clk_src[] = { >> + F(24000000, P_XO, 1, 0, 0), >> + F(133333333, P_GPLL0, 6, 0, 0), >> + F(266666667, P_GPLL0, 3, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 wcss_axi_m_clk_src = { >> + .cmd_rcgr = 0x25078, >> + .freq_tbl = ftbl_wcss_axi_m_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "wcss_axi_m_clk_src", >> + .parent_data = gcc_xo_gpll0, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_anoc_wcss_axi_m_clk = { >> + .halt_reg = 0x2e0a8, >> + .clkr = { >> + .enable_reg = 0x2e0a8, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_anoc_wcss_axi_m_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &wcss_axi_m_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_qdss_at_clk_src[] = { >> + F(240000000, P_GPLL4, 5, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 qdss_at_clk_src = { >> + .cmd_rcgr = 0x2d004, >> + .freq_tbl = ftbl_qdss_at_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll4_gpll0_gpll0_div2_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "qdss_at_clk_src", >> + .parent_data = gcc_xo_gpll4_gpll0_gpll0_div2, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll4_gpll0_gpll0_div2), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_q6ss_atbm_clk = { >> + .halt_reg = 0x2501c, >> + .clkr = { >> + .enable_reg = 0x2501c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_q6ss_atbm_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_at_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_wcss_dbg_ifc_atb_clk = { >> + .halt_reg = 0x2503c, >> + .clkr = { >> + .enable_reg = 0x2503c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_wcss_dbg_ifc_atb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_at_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nssnoc_atb_clk = { >> + .halt_reg = 0x17014, >> + .clkr = { >> + .enable_reg = 0x17014, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nssnoc_atb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_at_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_at_clk = { >> + .halt_reg = 0x2d038, >> + .clkr = { >> + .enable_reg = 0x2d038, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_at_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_at_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_sys_noc_at_clk = { >> + .halt_reg = 0x2e038, >> + .clkr = { >> + .enable_reg = 0x2e038, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_sys_noc_at_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_at_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_pcnoc_at_clk = { >> + .halt_reg = 0x31024, >> + .clkr = { >> + .enable_reg = 0x31024, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_pcnoc_at_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_at_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_fixed_factor gcc_eud_at_div_clk_src = { >> + .mult = 1, >> + .div = 6, >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_eud_at_div_clk_src", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_at_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_fixed_factor_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_usb0_eud_at_clk = { >> + .halt_reg = 0x30004, >> + .clkr = { >> + .enable_reg = 0x30004, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_usb0_eud_at_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &gcc_eud_at_div_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_eud_at_clk = { >> + .halt_reg = 0x2d06c, >> + .clkr = { >> + .enable_reg = 0x2d06c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_eud_at_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &gcc_eud_at_div_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_qdss_stm_clk_src[] = { >> + F(24000000, P_XO, 1, 0, 0), >> + F(200000000, P_GPLL0, 4, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 qdss_stm_clk_src = { >> + .cmd_rcgr = 0x2d00c, >> + .freq_tbl = ftbl_qdss_stm_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_gpll0_out_main_div2_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "qdss_stm_clk_src", >> + .parent_data = gcc_xo_gpll0_gpll0_out_main_div2, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_out_main_div2), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_stm_clk = { >> + .halt_reg = 0x2d03c, >> + .clkr = { >> + .enable_reg = 0x2d03c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_stm_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_stm_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_sys_noc_qdss_stm_axi_clk = { >> + .halt_reg = 0x2e034, >> + .clkr = { >> + .enable_reg = 0x2e034, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_sys_noc_qdss_stm_axi_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_stm_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_qdss_traceclkin_clk_src[] = { >> + F(300000000, P_GPLL4, 4, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 qdss_traceclkin_clk_src = { >> + .cmd_rcgr = 0x2d014, >> + .freq_tbl = ftbl_qdss_traceclkin_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll4_gpll0_gpll0_div2_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "qdss_traceclkin_clk_src", >> + .parent_data = gcc_xo_gpll4_gpll0_gpll0_div2, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll4_gpll0_gpll0_div2), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_traceclkin_clk = { >> + .halt_reg = 0x2d040, >> + .clkr = { >> + .enable_reg = 0x2d040, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_traceclkin_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_traceclkin_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_qdss_tsctr_clk_src[] = { >> + F(600000000, P_GPLL4, 2, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 qdss_tsctr_clk_src = { >> + .cmd_rcgr = 0x2d01c, >> + .freq_tbl = ftbl_qdss_tsctr_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll4_gpll0_gpll0_div2_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "qdss_tsctr_clk_src", >> + .parent_data = gcc_xo_gpll4_gpll0_gpll0_div2, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll4_gpll0_gpll0_div2), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_fixed_factor qdss_tsctr_div2_clk_src = { >> + .mult = 1, >> + .div = 2, >> + .hw.init = &(struct clk_init_data) { >> + .name = "qdss_tsctr_div2_clk_src", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_tsctr_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_fixed_factor_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_q6_tsctr_1to2_clk = { >> + .halt_reg = 0x25020, >> + .clkr = { >> + .enable_reg = 0x25020, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_q6_tsctr_1to2_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_tsctr_div2_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_wcss_dbg_ifc_nts_clk = { >> + .halt_reg = 0x25040, >> + .clkr = { >> + .enable_reg = 0x25040, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_wcss_dbg_ifc_nts_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_tsctr_div2_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_tsctr_div2_clk = { >> + .halt_reg = 0x2d044, >> + .clkr = { >> + .enable_reg = 0x2d044, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_tsctr_div2_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_tsctr_div2_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_uniphy_sys_clk_src[] = { >> + F(24000000, P_XO, 1, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 uniphy_sys_clk_src = { >> + .cmd_rcgr = 0x17090, >> + .freq_tbl = ftbl_uniphy_sys_clk_src, >> + .mnd_width = 8, >> + .hid_width = 5, >> + .parent_map = gcc_xo_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "uniphy_sys_clk_src", >> + .parent_data = gcc_xo_data, >> + .num_parents = ARRAY_SIZE(gcc_xo_data), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_rcg2 nss_ts_clk_src = { >> + .cmd_rcgr = 0x17088, >> + .freq_tbl = ftbl_uniphy_sys_clk_src, >> + .mnd_width = 8, >> + .hid_width = 5, >> + .parent_map = gcc_xo_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "nss_ts_clk_src", >> + .parent_data = gcc_xo_data, >> + .num_parents = ARRAY_SIZE(gcc_xo_data), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_ts_clk = { >> + .halt_reg = 0x2d078, >> + .clkr = { >> + .enable_reg = 0x2d078, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_ts_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &nss_ts_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_fixed_factor qdss_dap_sync_clk_src = { >> + .mult = 1, >> + .div = 4, >> + .hw.init = &(struct clk_init_data) { >> + .name = "qdss_dap_sync_clk_src", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_tsctr_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .ops = &clk_fixed_factor_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_tsctr_div4_clk = { >> + .halt_reg = 0x2d04c, >> + .clkr = { >> + .enable_reg = 0x2d04c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_tsctr_div4_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_dap_sync_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_fixed_factor qdss_tsctr_div8_clk_src = { >> + .mult = 1, >> + .div = 8, >> + .hw.init = &(struct clk_init_data) { >> + .name = "qdss_tsctr_div8_clk_src", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_tsctr_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .ops = &clk_fixed_factor_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nss_ts_clk = { >> + .halt_reg = 0x17018, >> + .clkr = { >> + .enable_reg = 0x17018, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nss_ts_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &nss_ts_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_tsctr_div8_clk = { >> + .halt_reg = 0x2d050, >> + .clkr = { >> + .enable_reg = 0x2d050, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_tsctr_div8_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_tsctr_div8_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_fixed_factor qdss_tsctr_div16_clk_src = { >> + .mult = 1, >> + .div = 16, >> + .hw.init = &(struct clk_init_data) { >> + .name = "qdss_tsctr_div16_clk_src", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_tsctr_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .ops = &clk_fixed_factor_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_tsctr_div16_clk = { >> + .halt_reg = 0x2d054, >> + .clkr = { >> + .enable_reg = 0x2d054, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_tsctr_div16_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_tsctr_div16_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_q6ss_pclkdbg_clk = { >> + .halt_reg = 0x25024, >> + .clkr = { >> + .enable_reg = 0x25024, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_q6ss_pclkdbg_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_dap_sync_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_q6ss_trig_clk = { >> + .halt_reg = 0x25068, >> + .clkr = { >> + .enable_reg = 0x25068, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_q6ss_trig_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_dap_sync_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_wcss_dbg_ifc_apb_clk = { >> + .halt_reg = 0x25038, >> + .clkr = { >> + .enable_reg = 0x25038, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_wcss_dbg_ifc_apb_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_dap_sync_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_wcss_dbg_ifc_dapbus_clk = { >> + .halt_reg = 0x25044, >> + .clkr = { >> + .enable_reg = 0x25044, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_wcss_dbg_ifc_dapbus_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_dap_sync_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_dap_clk = { >> + .halt_reg = 0x2d058, >> + .clkr = { >> + .enable_reg = 0x2d058, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_dap_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_dap_sync_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_apb2jtag_clk = { >> + .halt_reg = 0x2d05c, >> + .clkr = { >> + .enable_reg = 0x2d05c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_apb2jtag_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_dap_sync_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_fixed_factor qdss_tsctr_div3_clk_src = { >> + .mult = 1, >> + .div = 3, >> + .hw.init = &(struct clk_init_data) { >> + .name = "qdss_tsctr_div3_clk_src", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_tsctr_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .ops = &clk_fixed_factor_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qdss_tsctr_div3_clk = { >> + .halt_reg = 0x2d048, >> + .clkr = { >> + .enable_reg = 0x2d048, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_qdss_tsctr_div3_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &qdss_tsctr_div3_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_qpic_io_macro_clk_src[] = { >> + F(24000000, P_XO, 1, 0, 0), >> + F(100000000, P_GPLL0, 8, 0, 0), >> + F(200000000, P_GPLL0, 4, 0, 0), >> + F(320000000, P_GPLL0, 2.5, 0, 0), >> + F(400000000, P_GPLL0, 2, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 qpic_io_macro_clk_src = { >> + .cmd_rcgr = 0x32004, >> + .freq_tbl = ftbl_qpic_io_macro_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_gpll2_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "qpic_io_macro_clk_src", >> + .parent_data = gcc_xo_gpll0_gpll2, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll2), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_qpic_io_macro_clk = { >> + .halt_reg = 0x3200c, >> + .clkr = { >> + .enable_reg = 0x3200c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data){ >> + .name = "gcc_qpic_io_macro_clk", >> + .parent_hws = (const struct clk_hw *[]){ >> + &qpic_io_macro_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_q6_axi_clk_src[] = { >> + F(533333333, P_GPLL0, 1.5, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 q6_axi_clk_src = { >> + .cmd_rcgr = 0x25004, >> + .freq_tbl = ftbl_q6_axi_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_gpll2_gpll4_pi_sleep_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "q6_axi_clk_src", >> + .parent_data = gcc_xo_gpll0_gpll2_gpll4_pi_sleep, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll2_gpll4_pi_sleep), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_q6_axim_clk = { >> + .halt_reg = 0x2500c, >> + .clkr = { >> + .enable_reg = 0x2500c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_q6_axim_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &q6_axi_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_wcss_q6_tbu_clk = { >> + .halt_reg = 0x12050, >> + .halt_check = BRANCH_HALT_DELAY, >> + .clkr = { >> + .enable_reg = 0xb00c, >> + .enable_mask = BIT(6), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_wcss_q6_tbu_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &q6_axi_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_mem_noc_q6_axi_clk = { >> + .halt_reg = 0x19010, >> + .clkr = { >> + .enable_reg = 0x19010, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_mem_noc_q6_axi_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &q6_axi_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_q6_axim2_clk_src[] = { >> + F(342857143, P_GPLL4, 3.5, 0, 0), >> + { } >> +}; >> + >> +static const struct parent_map gcc_xo_gpll0_gpll4_bias_pll_ubinc_clk_map[] = { >> + { P_XO, 0 }, >> + { P_GPLL0, 1 }, >> + { P_GPLL4, 2 }, >> + { P_BIAS_PLL_UBI_NC_CLK, 4 }, >> +}; >> + >> +static struct clk_rcg2 q6_axim2_clk_src = { >> + .cmd_rcgr = 0x25028, >> + .freq_tbl = ftbl_q6_axim2_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_gpll4_bias_pll_ubinc_clk_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "q6_axim2_clk_src", >> + .parent_data = gcc_xo_gpll0_gpll4_bias_pll_ubi_nc_clk, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll4_bias_pll_ubi_nc_clk), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_nssnoc_memnoc_bfdcd_clk_src[] = { >> + F(533333333, P_GPLL0, 1.5, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 nssnoc_memnoc_bfdcd_clk_src = { >> + .cmd_rcgr = 0x17004, >> + .freq_tbl = ftbl_nssnoc_memnoc_bfdcd_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_gpll0_aux_gpll2_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "nssnoc_memnoc_bfdcd_clk_src", >> + .parent_data = gcc_xo_gpll0_gpll0_aux_gpll2, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_aux_gpll2), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nssnoc_memnoc_clk = { >> + .halt_reg = 0x17024, >> + .clkr = { >> + .enable_reg = 0x17024, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nssnoc_memnoc_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &nssnoc_memnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nssnoc_mem_noc_1_clk = { >> + .halt_reg = 0x17084, >> + .clkr = { >> + .enable_reg = 0x17084, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nssnoc_mem_noc_1_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &nssnoc_memnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nss_tbu_clk = { >> + .halt_reg = 0x12040, >> + .clkr = { >> + .enable_reg = 0xb00c, >> + .enable_mask = BIT(4), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nss_tbu_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &nssnoc_memnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_mem_noc_nssnoc_clk = { >> + .halt_reg = 0x19014, >> + .clkr = { >> + .enable_reg = 0x19014, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_mem_noc_nssnoc_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &nssnoc_memnoc_bfdcd_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_lpass_axim_clk_src[] = { >> + F(133333333, P_GPLL0, 6, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 lpass_axim_clk_src = { >> + .cmd_rcgr = 0x2700c, >> + .freq_tbl = ftbl_lpass_axim_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "lpass_axim_clk_src", >> + .parent_data = gcc_xo_gpll0, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_rcg2 lpass_sway_clk_src = { >> + .cmd_rcgr = 0x27004, >> + .freq_tbl = ftbl_lpass_axim_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "lpass_sway_clk_src", >> + .parent_data = gcc_xo_gpll0, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_adss_pwm_clk_src[] = { >> + F(24000000, P_XO, 1, 0, 0), >> + F(100000000, P_GPLL0, 8, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 adss_pwm_clk_src = { >> + .cmd_rcgr = 0x1c004, >> + .freq_tbl = ftbl_adss_pwm_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "adss_pwm_clk_src", >> + .parent_data = gcc_xo_gpll0, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_adss_pwm_clk = { >> + .halt_reg = 0x1c00c, >> + .clkr = { >> + .enable_reg = 0x1c00c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_adss_pwm_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &adss_pwm_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static const struct freq_tbl ftbl_gp1_clk_src[] = { >> + F(24000000, P_XO, 1, 0, 0), >> + F(200000000, P_GPLL0, 4, 0, 0), >> + { } >> +}; >> + >> +static struct clk_rcg2 gp1_clk_src = { >> + .cmd_rcgr = 0x8004, >> + .freq_tbl = ftbl_gp1_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_gpll0_sleep_clk_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "gp1_clk_src", >> + .parent_data = gcc_xo_gpll0_gpll0_sleep_clk, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_sleep_clk), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_rcg2 gp2_clk_src = { >> + .cmd_rcgr = 0x9004, >> + .freq_tbl = ftbl_gp1_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_gpll0_sleep_clk_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "gp2_clk_src", >> + .parent_data = gcc_xo_gpll0_gpll0_sleep_clk, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_sleep_clk), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_rcg2 gp3_clk_src = { >> + .cmd_rcgr = 0xa004, >> + .freq_tbl = ftbl_gp1_clk_src, >> + .hid_width = 5, >> + .parent_map = gcc_xo_gpll0_gpll0_sleep_clk_map, >> + .clkr.hw.init = &(struct clk_init_data) { >> + .name = "gp3_clk_src", >> + .parent_data = gcc_xo_gpll0_gpll0_sleep_clk, >> + .num_parents = ARRAY_SIZE(gcc_xo_gpll0_gpll0_sleep_clk), >> + .ops = &clk_rcg2_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_xo_clk_src = { >> + .halt_reg = 0x34004, >> + .clkr = { >> + .enable_reg = 0x34004, >> + .enable_mask = BIT(1), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_xo_clk_src", >> + .parent_data = gcc_xo_data, >> + .num_parents = ARRAY_SIZE(gcc_xo_data), >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nssnoc_xo_dcd_clk = { >> + .halt_reg = 0x17074, >> + .clkr = { >> + .enable_reg = 0x17074, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nssnoc_xo_dcd_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &gcc_xo_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_xo_clk = { >> + .halt_reg = 0x34018, >> + .clkr = { >> + .enable_reg = 0x34018, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_xo_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &gcc_xo_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_uniphy0_sys_clk = { >> + .halt_reg = 0x17048, >> + .clkr = { >> + .enable_reg = 0x17048, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_uniphy0_sys_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &uniphy_sys_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_uniphy1_sys_clk = { >> + .halt_reg = 0x17058, >> + .clkr = { >> + .enable_reg = 0x17058, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_uniphy1_sys_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &uniphy_sys_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_uniphy2_sys_clk = { >> + .halt_reg = 0x17068, >> + .clkr = { >> + .enable_reg = 0x17068, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_uniphy2_sys_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &uniphy_sys_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_cmn_12gpll_sys_clk = { >> + .halt_reg = 0x3a008, >> + .clkr = { >> + .enable_reg = 0x3a008, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_cmn_12gpll_sys_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &uniphy_sys_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_fixed_factor gcc_xo_div4_clk_src = { >> + .mult = 1, >> + .div = 4, >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_xo_div4_clk_src", >> + .parent_hws = (const struct clk_hw *[]) { >> + &gcc_xo_clk_src.clkr.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_fixed_factor_ops, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nssnoc_qosgen_ref_clk = { >> + .halt_reg = 0x1701c, >> + .clkr = { >> + .enable_reg = 0x1701c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nssnoc_qosgen_ref_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &gcc_xo_div4_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_nssnoc_timeout_ref_clk = { >> + .halt_reg = 0x17020, >> + .clkr = { >> + .enable_reg = 0x17020, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_nssnoc_timeout_ref_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &gcc_xo_div4_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_branch gcc_xo_div4_clk = { >> + .halt_reg = 0x3401c, >> + .clkr = { >> + .enable_reg = 0x3401c, >> + .enable_mask = BIT(0), >> + .hw.init = &(struct clk_init_data) { >> + .name = "gcc_xo_div4_clk", >> + .parent_hws = (const struct clk_hw *[]) { >> + &gcc_xo_div4_clk_src.hw >> + }, >> + .num_parents = 1, >> + .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL, >> + .ops = &clk_branch2_ops, >> + }, >> + }, >> +}; >> + >> +static struct clk_hw *gcc_ipq9574_hws[] = { >> + &gpll0_out_main_div2.hw, >> + &gcc_xo_div4_clk_src.hw, >> + &qdss_dap_sync_clk_src.hw, >> + &qdss_tsctr_div2_clk_src.hw, >> + &qdss_tsctr_div8_clk_src.hw, >> + &qdss_tsctr_div16_clk_src.hw, >> + &qdss_tsctr_div3_clk_src.hw, >> + &gcc_eud_at_div_clk_src.hw, >> +}; >> + >> +static struct clk_regmap *gcc_ipq9574_clks[] = { >> + [GPLL0_MAIN] = &gpll0_main.clkr, >> + [GPLL0] = &gpll0.clkr, >> + [GPLL4_MAIN] = &gpll4_main.clkr, >> + [GPLL4] = &gpll4.clkr, >> + [GPLL2_MAIN] = &gpll2_main.clkr, >> + [GPLL2] = &gpll2.clkr, >> + [GCC_SLEEP_CLK_SRC] = &gcc_sleep_clk_src.clkr, >> + [APSS_AHB_CLK_SRC] = &apss_ahb_clk_src.clkr, >> + [APSS_AXI_CLK_SRC] = &apss_axi_clk_src.clkr, >> + [BLSP1_QUP1_I2C_APPS_CLK_SRC] = &blsp1_qup1_i2c_apps_clk_src.clkr, >> + [BLSP1_QUP1_SPI_APPS_CLK_SRC] = &blsp1_qup1_spi_apps_clk_src.clkr, >> + [BLSP1_QUP2_I2C_APPS_CLK_SRC] = &blsp1_qup2_i2c_apps_clk_src.clkr, >> + [BLSP1_QUP2_SPI_APPS_CLK_SRC] = &blsp1_qup2_spi_apps_clk_src.clkr, >> + [BLSP1_QUP3_I2C_APPS_CLK_SRC] = &blsp1_qup3_i2c_apps_clk_src.clkr, >> + [BLSP1_QUP3_SPI_APPS_CLK_SRC] = &blsp1_qup3_spi_apps_clk_src.clkr, >> + [BLSP1_QUP4_I2C_APPS_CLK_SRC] = &blsp1_qup4_i2c_apps_clk_src.clkr, >> + [BLSP1_QUP4_SPI_APPS_CLK_SRC] = &blsp1_qup4_spi_apps_clk_src.clkr, >> + [BLSP1_QUP5_I2C_APPS_CLK_SRC] = &blsp1_qup5_i2c_apps_clk_src.clkr, >> + [BLSP1_QUP5_SPI_APPS_CLK_SRC] = &blsp1_qup5_spi_apps_clk_src.clkr, >> + [BLSP1_QUP6_I2C_APPS_CLK_SRC] = &blsp1_qup6_i2c_apps_clk_src.clkr, >> + [BLSP1_QUP6_SPI_APPS_CLK_SRC] = &blsp1_qup6_spi_apps_clk_src.clkr, >> + [BLSP1_UART1_APPS_CLK_SRC] = &blsp1_uart1_apps_clk_src.clkr, >> + [BLSP1_UART2_APPS_CLK_SRC] = &blsp1_uart2_apps_clk_src.clkr, >> + [BLSP1_UART3_APPS_CLK_SRC] = &blsp1_uart3_apps_clk_src.clkr, >> + [BLSP1_UART4_APPS_CLK_SRC] = &blsp1_uart4_apps_clk_src.clkr, >> + [BLSP1_UART5_APPS_CLK_SRC] = &blsp1_uart5_apps_clk_src.clkr, >> + [BLSP1_UART6_APPS_CLK_SRC] = &blsp1_uart6_apps_clk_src.clkr, >> + [GCC_APSS_AHB_CLK] = &gcc_apss_ahb_clk.clkr, >> + [GCC_APSS_AXI_CLK] = &gcc_apss_axi_clk.clkr, >> + [GCC_BLSP1_QUP1_I2C_APPS_CLK] = &gcc_blsp1_qup1_i2c_apps_clk.clkr, >> + [GCC_BLSP1_QUP1_SPI_APPS_CLK] = &gcc_blsp1_qup1_spi_apps_clk.clkr, >> + [GCC_BLSP1_QUP2_I2C_APPS_CLK] = &gcc_blsp1_qup2_i2c_apps_clk.clkr, >> + [GCC_BLSP1_QUP2_SPI_APPS_CLK] = &gcc_blsp1_qup2_spi_apps_clk.clkr, >> + [GCC_BLSP1_QUP3_I2C_APPS_CLK] = &gcc_blsp1_qup3_i2c_apps_clk.clkr, >> + [GCC_BLSP1_QUP3_SPI_APPS_CLK] = &gcc_blsp1_qup3_spi_apps_clk.clkr, >> + [GCC_BLSP1_QUP4_I2C_APPS_CLK] = &gcc_blsp1_qup4_i2c_apps_clk.clkr, >> + [GCC_BLSP1_QUP4_SPI_APPS_CLK] = &gcc_blsp1_qup4_spi_apps_clk.clkr, >> + [GCC_BLSP1_QUP5_I2C_APPS_CLK] = &gcc_blsp1_qup5_i2c_apps_clk.clkr, >> + [GCC_BLSP1_QUP5_SPI_APPS_CLK] = &gcc_blsp1_qup5_spi_apps_clk.clkr, >> + [GCC_BLSP1_QUP6_I2C_APPS_CLK] = &gcc_blsp1_qup6_i2c_apps_clk.clkr, >> + [GCC_BLSP1_QUP6_SPI_APPS_CLK] = &gcc_blsp1_qup6_spi_apps_clk.clkr, >> + [GCC_BLSP1_UART1_APPS_CLK] = &gcc_blsp1_uart1_apps_clk.clkr, >> + [GCC_BLSP1_UART2_APPS_CLK] = &gcc_blsp1_uart2_apps_clk.clkr, >> + [GCC_BLSP1_UART3_APPS_CLK] = &gcc_blsp1_uart3_apps_clk.clkr, >> + [GCC_BLSP1_UART4_APPS_CLK] = &gcc_blsp1_uart4_apps_clk.clkr, >> + [GCC_BLSP1_UART5_APPS_CLK] = &gcc_blsp1_uart5_apps_clk.clkr, >> + [GCC_BLSP1_UART6_APPS_CLK] = &gcc_blsp1_uart6_apps_clk.clkr, >> + [PCIE0_AXI_M_CLK_SRC] = &pcie0_axi_m_clk_src.clkr, >> + [GCC_PCIE0_AXI_M_CLK] = &gcc_pcie0_axi_m_clk.clkr, >> + [PCIE1_AXI_M_CLK_SRC] = &pcie1_axi_m_clk_src.clkr, >> + [GCC_PCIE1_AXI_M_CLK] = &gcc_pcie1_axi_m_clk.clkr, >> + [PCIE2_AXI_M_CLK_SRC] = &pcie2_axi_m_clk_src.clkr, >> + [GCC_PCIE2_AXI_M_CLK] = &gcc_pcie2_axi_m_clk.clkr, >> + [PCIE3_AXI_M_CLK_SRC] = &pcie3_axi_m_clk_src.clkr, >> + [GCC_PCIE3_AXI_M_CLK] = &gcc_pcie3_axi_m_clk.clkr, >> + [PCIE0_AXI_S_CLK_SRC] = &pcie0_axi_s_clk_src.clkr, >> + [GCC_PCIE0_AXI_S_BRIDGE_CLK] = &gcc_pcie0_axi_s_bridge_clk.clkr, >> + [GCC_PCIE0_AXI_S_CLK] = &gcc_pcie0_axi_s_clk.clkr, >> + [PCIE1_AXI_S_CLK_SRC] = &pcie1_axi_s_clk_src.clkr, >> + [GCC_PCIE1_AXI_S_BRIDGE_CLK] = &gcc_pcie1_axi_s_bridge_clk.clkr, >> + [GCC_PCIE1_AXI_S_CLK] = &gcc_pcie1_axi_s_clk.clkr, >> + [PCIE2_AXI_S_CLK_SRC] = &pcie2_axi_s_clk_src.clkr, >> + [GCC_PCIE2_AXI_S_BRIDGE_CLK] = &gcc_pcie2_axi_s_bridge_clk.clkr, >> + [GCC_PCIE2_AXI_S_CLK] = &gcc_pcie2_axi_s_clk.clkr, >> + [PCIE3_AXI_S_CLK_SRC] = &pcie3_axi_s_clk_src.clkr, >> + [GCC_PCIE3_AXI_S_BRIDGE_CLK] = &gcc_pcie3_axi_s_bridge_clk.clkr, >> + [GCC_PCIE3_AXI_S_CLK] = &gcc_pcie3_axi_s_clk.clkr, >> + [PCIE0_PIPE_CLK_SRC] = &pcie0_pipe_clk_src.clkr, >> + [PCIE1_PIPE_CLK_SRC] = &pcie1_pipe_clk_src.clkr, >> + [PCIE2_PIPE_CLK_SRC] = &pcie2_pipe_clk_src.clkr, >> + [PCIE3_PIPE_CLK_SRC] = &pcie3_pipe_clk_src.clkr, >> + [PCIE_AUX_CLK_SRC] = &pcie_aux_clk_src.clkr, >> + [GCC_PCIE0_AUX_CLK] = &gcc_pcie0_aux_clk.clkr, >> + [GCC_PCIE1_AUX_CLK] = &gcc_pcie1_aux_clk.clkr, >> + [GCC_PCIE2_AUX_CLK] = &gcc_pcie2_aux_clk.clkr, >> + [GCC_PCIE3_AUX_CLK] = &gcc_pcie3_aux_clk.clkr, >> + [PCIE0_RCHNG_CLK_SRC] = &pcie0_rchng_clk_src.clkr, >> + [GCC_PCIE0_RCHNG_CLK] = &gcc_pcie0_rchng_clk.clkr, >> + [PCIE1_RCHNG_CLK_SRC] = &pcie1_rchng_clk_src.clkr, >> + [GCC_PCIE1_RCHNG_CLK] = &gcc_pcie1_rchng_clk.clkr, >> + [PCIE2_RCHNG_CLK_SRC] = &pcie2_rchng_clk_src.clkr, >> + [GCC_PCIE2_RCHNG_CLK] = &gcc_pcie2_rchng_clk.clkr, >> + [PCIE3_RCHNG_CLK_SRC] = &pcie3_rchng_clk_src.clkr, >> + [GCC_PCIE3_RCHNG_CLK] = &gcc_pcie3_rchng_clk.clkr, >> + [GCC_PCIE0_AHB_CLK] = &gcc_pcie0_ahb_clk.clkr, >> + [GCC_PCIE1_AHB_CLK] = &gcc_pcie1_ahb_clk.clkr, >> + [GCC_PCIE2_AHB_CLK] = &gcc_pcie2_ahb_clk.clkr, >> + [GCC_PCIE3_AHB_CLK] = &gcc_pcie3_ahb_clk.clkr, >> + [USB0_AUX_CLK_SRC] = &usb0_aux_clk_src.clkr, >> + [GCC_USB0_AUX_CLK] = &gcc_usb0_aux_clk.clkr, >> + [USB0_MASTER_CLK_SRC] = &usb0_master_clk_src.clkr, >> + [GCC_USB0_MASTER_CLK] = &gcc_usb0_master_clk.clkr, >> + [GCC_SNOC_USB_CLK] = &gcc_snoc_usb_clk.clkr, >> + [GCC_ANOC_USB_AXI_CLK] = &gcc_anoc_usb_axi_clk.clkr, >> + [USB0_MOCK_UTMI_CLK_SRC] = &usb0_mock_utmi_clk_src.clkr, >> + [USB0_MOCK_UTMI_DIV_CLK_SRC] = &usb0_mock_utmi_div_clk_src.clkr, >> + [GCC_USB0_MOCK_UTMI_CLK] = &gcc_usb0_mock_utmi_clk.clkr, >> + [USB0_PIPE_CLK_SRC] = &usb0_pipe_clk_src.clkr, >> + [GCC_USB0_PHY_CFG_AHB_CLK] = &gcc_usb0_phy_cfg_ahb_clk.clkr, >> + [SDCC1_APPS_CLK_SRC] = &sdcc1_apps_clk_src.clkr, >> + [GCC_SDCC1_APPS_CLK] = &gcc_sdcc1_apps_clk.clkr, >> + [SDCC1_ICE_CORE_CLK_SRC] = &sdcc1_ice_core_clk_src.clkr, >> + [GCC_SDCC1_ICE_CORE_CLK] = &gcc_sdcc1_ice_core_clk.clkr, >> + [GCC_SDCC1_AHB_CLK] = &gcc_sdcc1_ahb_clk.clkr, >> + [PCNOC_BFDCD_CLK_SRC] = &pcnoc_bfdcd_clk_src.clkr, >> + [GCC_NSSCFG_CLK] = &gcc_nsscfg_clk.clkr, >> + [GCC_NSSNOC_NSSCC_CLK] = &gcc_nssnoc_nsscc_clk.clkr, >> + [GCC_NSSCC_CLK] = &gcc_nsscc_clk.clkr, >> + [GCC_NSSNOC_PCNOC_1_CLK] = &gcc_nssnoc_pcnoc_1_clk.clkr, >> + [GCC_QDSS_DAP_AHB_CLK] = &gcc_qdss_dap_ahb_clk.clkr, >> + [GCC_QDSS_CFG_AHB_CLK] = &gcc_qdss_cfg_ahb_clk.clkr, >> + [GCC_QPIC_AHB_CLK] = &gcc_qpic_ahb_clk.clkr, >> + [GCC_QPIC_CLK] = &gcc_qpic_clk.clkr, >> + [GCC_BLSP1_AHB_CLK] = &gcc_blsp1_ahb_clk.clkr, >> + [GCC_MDIO_AHB_CLK] = &gcc_mdio_ahb_clk.clkr, >> + [GCC_PRNG_AHB_CLK] = &gcc_prng_ahb_clk.clkr, >> + [GCC_UNIPHY0_AHB_CLK] = &gcc_uniphy0_ahb_clk.clkr, >> + [GCC_UNIPHY1_AHB_CLK] = &gcc_uniphy1_ahb_clk.clkr, >> + [GCC_UNIPHY2_AHB_CLK] = &gcc_uniphy2_ahb_clk.clkr, >> + [GCC_CMN_12GPLL_AHB_CLK] = &gcc_cmn_12gpll_ahb_clk.clkr, >> + [GCC_CMN_12GPLL_APU_CLK] = &gcc_cmn_12gpll_apu_clk.clkr, >> + [SYSTEM_NOC_BFDCD_CLK_SRC] = &system_noc_bfdcd_clk_src.clkr, >> + [GCC_NSSNOC_SNOC_CLK] = &gcc_nssnoc_snoc_clk.clkr, >> + [GCC_NSSNOC_SNOC_1_CLK] = &gcc_nssnoc_snoc_1_clk.clkr, >> + [GCC_QDSS_ETR_USB_CLK] = &gcc_qdss_etr_usb_clk.clkr, >> + [WCSS_AHB_CLK_SRC] = &wcss_ahb_clk_src.clkr, >> + [GCC_Q6_AHB_CLK] = &gcc_q6_ahb_clk.clkr, >> + [GCC_Q6_AHB_S_CLK] = &gcc_q6_ahb_s_clk.clkr, >> + [GCC_WCSS_ECAHB_CLK] = &gcc_wcss_ecahb_clk.clkr, >> + [GCC_WCSS_ACMT_CLK] = &gcc_wcss_acmt_clk.clkr, >> + [GCC_SYS_NOC_WCSS_AHB_CLK] = &gcc_sys_noc_wcss_ahb_clk.clkr, >> + [WCSS_AXI_M_CLK_SRC] = &wcss_axi_m_clk_src.clkr, >> + [GCC_ANOC_WCSS_AXI_M_CLK] = &gcc_anoc_wcss_axi_m_clk.clkr, >> + [QDSS_AT_CLK_SRC] = &qdss_at_clk_src.clkr, >> + [GCC_Q6SS_ATBM_CLK] = &gcc_q6ss_atbm_clk.clkr, >> + [GCC_WCSS_DBG_IFC_ATB_CLK] = &gcc_wcss_dbg_ifc_atb_clk.clkr, >> + [GCC_NSSNOC_ATB_CLK] = &gcc_nssnoc_atb_clk.clkr, >> + [GCC_QDSS_AT_CLK] = &gcc_qdss_at_clk.clkr, >> + [GCC_SYS_NOC_AT_CLK] = &gcc_sys_noc_at_clk.clkr, >> + [GCC_PCNOC_AT_CLK] = &gcc_pcnoc_at_clk.clkr, >> + [GCC_USB0_EUD_AT_CLK] = &gcc_usb0_eud_at_clk.clkr, >> + [GCC_QDSS_EUD_AT_CLK] = &gcc_qdss_eud_at_clk.clkr, >> + [QDSS_STM_CLK_SRC] = &qdss_stm_clk_src.clkr, >> + [GCC_QDSS_STM_CLK] = &gcc_qdss_stm_clk.clkr, >> + [GCC_SYS_NOC_QDSS_STM_AXI_CLK] = &gcc_sys_noc_qdss_stm_axi_clk.clkr, >> + [QDSS_TRACECLKIN_CLK_SRC] = &qdss_traceclkin_clk_src.clkr, >> + [GCC_QDSS_TRACECLKIN_CLK] = &gcc_qdss_traceclkin_clk.clkr, >> + [QDSS_TSCTR_CLK_SRC] = &qdss_tsctr_clk_src.clkr, >> + [GCC_Q6_TSCTR_1TO2_CLK] = &gcc_q6_tsctr_1to2_clk.clkr, >> + [GCC_WCSS_DBG_IFC_NTS_CLK] = &gcc_wcss_dbg_ifc_nts_clk.clkr, >> + [GCC_QDSS_TSCTR_DIV2_CLK] = &gcc_qdss_tsctr_div2_clk.clkr, >> + [GCC_QDSS_TS_CLK] = &gcc_qdss_ts_clk.clkr, >> + [GCC_QDSS_TSCTR_DIV4_CLK] = &gcc_qdss_tsctr_div4_clk.clkr, >> + [GCC_NSS_TS_CLK] = &gcc_nss_ts_clk.clkr, >> + [GCC_QDSS_TSCTR_DIV8_CLK] = &gcc_qdss_tsctr_div8_clk.clkr, >> + [GCC_QDSS_TSCTR_DIV16_CLK] = &gcc_qdss_tsctr_div16_clk.clkr, >> + [GCC_Q6SS_PCLKDBG_CLK] = &gcc_q6ss_pclkdbg_clk.clkr, >> + [GCC_Q6SS_TRIG_CLK] = &gcc_q6ss_trig_clk.clkr, >> + [GCC_WCSS_DBG_IFC_APB_CLK] = &gcc_wcss_dbg_ifc_apb_clk.clkr, >> + [GCC_WCSS_DBG_IFC_DAPBUS_CLK] = &gcc_wcss_dbg_ifc_dapbus_clk.clkr, >> + [GCC_QDSS_DAP_CLK] = &gcc_qdss_dap_clk.clkr, >> + [GCC_QDSS_APB2JTAG_CLK] = &gcc_qdss_apb2jtag_clk.clkr, >> + [GCC_QDSS_TSCTR_DIV3_CLK] = &gcc_qdss_tsctr_div3_clk.clkr, >> + [QPIC_IO_MACRO_CLK_SRC] = &qpic_io_macro_clk_src.clkr, >> + [GCC_QPIC_IO_MACRO_CLK] = &gcc_qpic_io_macro_clk.clkr, >> + [Q6_AXI_CLK_SRC] = &q6_axi_clk_src.clkr, >> + [GCC_Q6_AXIM_CLK] = &gcc_q6_axim_clk.clkr, >> + [GCC_WCSS_Q6_TBU_CLK] = &gcc_wcss_q6_tbu_clk.clkr, >> + [GCC_MEM_NOC_Q6_AXI_CLK] = &gcc_mem_noc_q6_axi_clk.clkr, >> + [Q6_AXIM2_CLK_SRC] = &q6_axim2_clk_src.clkr, >> + [NSSNOC_MEMNOC_BFDCD_CLK_SRC] = &nssnoc_memnoc_bfdcd_clk_src.clkr, >> + [GCC_NSSNOC_MEMNOC_CLK] = &gcc_nssnoc_memnoc_clk.clkr, >> + [GCC_NSSNOC_MEM_NOC_1_CLK] = &gcc_nssnoc_mem_noc_1_clk.clkr, >> + [GCC_NSS_TBU_CLK] = &gcc_nss_tbu_clk.clkr, >> + [GCC_MEM_NOC_NSSNOC_CLK] = &gcc_mem_noc_nssnoc_clk.clkr, >> + [LPASS_AXIM_CLK_SRC] = &lpass_axim_clk_src.clkr, >> + [LPASS_SWAY_CLK_SRC] = &lpass_sway_clk_src.clkr, >> + [ADSS_PWM_CLK_SRC] = &adss_pwm_clk_src.clkr, >> + [GCC_ADSS_PWM_CLK] = &gcc_adss_pwm_clk.clkr, >> + [GP1_CLK_SRC] = &gp1_clk_src.clkr, >> + [GP2_CLK_SRC] = &gp2_clk_src.clkr, >> + [GP3_CLK_SRC] = &gp3_clk_src.clkr, >> + [GCC_XO_CLK_SRC] = &gcc_xo_clk_src.clkr, >> + [GCC_NSSNOC_XO_DCD_CLK] = &gcc_nssnoc_xo_dcd_clk.clkr, >> + [GCC_XO_CLK] = &gcc_xo_clk.clkr, >> + [GCC_NSSNOC_QOSGEN_REF_CLK] = &gcc_nssnoc_qosgen_ref_clk.clkr, >> + [GCC_NSSNOC_TIMEOUT_REF_CLK] = &gcc_nssnoc_timeout_ref_clk.clkr, >> + [GCC_XO_DIV4_CLK] = &gcc_xo_div4_clk.clkr, >> + [GCC_UNIPHY0_SYS_CLK] = &gcc_uniphy0_sys_clk.clkr, >> + [GCC_UNIPHY1_SYS_CLK] = &gcc_uniphy1_sys_clk.clkr, >> + [GCC_UNIPHY2_SYS_CLK] = &gcc_uniphy2_sys_clk.clkr, >> + [GCC_CMN_12GPLL_SYS_CLK] = &gcc_cmn_12gpll_sys_clk.clkr, >> + [GCC_Q6SS_BOOT_CLK] = &gcc_q6ss_boot_clk.clkr, >> + [UNIPHY_SYS_CLK_SRC] = &uniphy_sys_clk_src.clkr, >> + [NSS_TS_CLK_SRC] = &nss_ts_clk_src.clkr, >> + [GCC_ANOC_PCIE0_1LANE_M_CLK] = &gcc_anoc_pcie0_1lane_m_clk.clkr, >> + [GCC_ANOC_PCIE1_1LANE_M_CLK] = &gcc_anoc_pcie1_1lane_m_clk.clkr, >> + [GCC_ANOC_PCIE2_2LANE_M_CLK] = &gcc_anoc_pcie2_2lane_m_clk.clkr, >> + [GCC_ANOC_PCIE3_2LANE_M_CLK] = &gcc_anoc_pcie3_2lane_m_clk.clkr, >> + [GCC_SNOC_PCIE0_1LANE_S_CLK] = &gcc_snoc_pcie0_1lane_s_clk.clkr, >> + [GCC_SNOC_PCIE1_1LANE_S_CLK] = &gcc_snoc_pcie1_1lane_s_clk.clkr, >> + [GCC_SNOC_PCIE2_2LANE_S_CLK] = &gcc_snoc_pcie2_2lane_s_clk.clkr, >> + [GCC_SNOC_PCIE3_2LANE_S_CLK] = &gcc_snoc_pcie3_2lane_s_clk.clkr, >> +}; >> + >> +static const struct qcom_reset_map gcc_ipq9574_resets[] = { >> + [GCC_ADSS_BCR] = { 0x1c000, 0 }, >> + [GCC_ANOC0_TBU_BCR] = { 0x1203c, 0 }, >> + [GCC_ANOC1_TBU_BCR] = { 0x1204c, 0 }, >> + [GCC_ANOC_BCR] = { 0x2e074, 0 }, >> + [GCC_APC0_VOLTAGE_DROOP_DETECTOR_BCR] = { 0x38000, 0 }, >> + [GCC_APSS_TCU_BCR] = { 0x12014, 0 }, >> + [GCC_BLSP1_BCR] = { 0x01000, 0 }, >> + [GCC_BLSP1_QUP1_BCR] = { 0x02000, 0 }, >> + [GCC_BLSP1_QUP2_BCR] = { 0x03000, 0 }, >> + [GCC_BLSP1_QUP3_BCR] = { 0x04000, 0 }, >> + [GCC_BLSP1_QUP4_BCR] = { 0x05000, 0 }, >> + [GCC_BLSP1_QUP5_BCR] = { 0x06000, 0 }, >> + [GCC_BLSP1_QUP6_BCR] = { 0x07000, 0 }, >> + [GCC_BLSP1_UART1_BCR] = { 0x02028, 0 }, >> + [GCC_BLSP1_UART2_BCR] = { 0x03028, 0 }, >> + [GCC_BLSP1_UART3_BCR] = { 0x04028, 0 }, >> + [GCC_BLSP1_UART4_BCR] = { 0x05028, 0 }, >> + [GCC_BLSP1_UART5_BCR] = { 0x06028, 0 }, >> + [GCC_BLSP1_UART6_BCR] = { 0x07028, 0 }, >> + [GCC_BOOT_ROM_BCR] = { 0x13028, 0 }, >> + [GCC_CMN_BLK_BCR] = { 0x3a000, 0 }, >> + [GCC_CMN_BLK_AHB_ARES] = { 0x3a010, 0 }, >> + [GCC_CMN_BLK_SYS_ARES] = { 0x3a010, 1 }, >> + [GCC_CMN_BLK_APU_ARES] = { 0x3a010, 2 }, >> + [GCC_DCC_BCR] = { 0x35000, 0 }, >> + [GCC_DDRSS_BCR] = { 0x11000, 0 }, >> + [GCC_IMEM_BCR] = { 0x0e000, 0 }, >> + [GCC_LPASS_BCR] = { 0x27000, 0 }, >> + [GCC_MDIO_BCR] = { 0x1703c, 0 }, >> + [GCC_MPM_BCR] = { 0x37000, 0 }, >> + [GCC_MSG_RAM_BCR] = { 0x26000, 0 }, >> + [GCC_NSS_BCR] = { 0x17000, 0 }, >> + [GCC_NSS_TBU_BCR] = { 0x12044, 0 }, >> + [GCC_NSSNOC_MEMNOC_1_ARES] = { 0x17038, 13 }, >> + [GCC_NSSNOC_PCNOC_1_ARES] = { 0x17038, 12 }, >> + [GCC_NSSNOC_SNOC_1_ARES] = { 0x17038, 11 }, >> + [GCC_NSSNOC_XO_DCD_ARES] = { 0x17038, 10 }, >> + [GCC_NSSNOC_TS_ARES] = { 0x17038, 9 }, >> + [GCC_NSSCC_ARES] = { 0x17038, 8 }, >> + [GCC_NSSNOC_NSSCC_ARES] = { 0x17038, 7 }, >> + [GCC_NSSNOC_ATB_ARES] = { 0x17038, 6 }, >> + [GCC_NSSNOC_MEMNOC_ARES] = { 0x17038, 5 }, >> + [GCC_NSSNOC_QOSGEN_REF_ARES] = { 0x17038, 4 }, >> + [GCC_NSSNOC_SNOC_ARES] = { 0x17038, 3 }, >> + [GCC_NSSNOC_TIMEOUT_REF_ARES] = { 0x17038, 2 }, >> + [GCC_NSS_CFG_ARES] = { 0x17038, 1 }, >> + [GCC_UBI0_DBG_ARES] = { 0x17038, 0 }, >> + [GCC_PCIE0PHY_PHY_BCR] = { 0x2805c, 0 }, >> + [GCC_PCIE0_AHB_ARES] = { 0x28058, 7 }, >> + [GCC_PCIE0_AUX_ARES] = { 0x28058, 6 }, >> + [GCC_PCIE0_AXI_M_ARES] = { 0x28058, 5 }, >> + [GCC_PCIE0_AXI_M_STICKY_ARES] = { 0x28058, 4 }, >> + [GCC_PCIE0_AXI_S_ARES] = { 0x28058, 3 }, >> + [GCC_PCIE0_AXI_S_STICKY_ARES] = { 0x28058, 2 }, >> + [GCC_PCIE0_CORE_STICKY_ARES] = { 0x28058, 1 }, >> + [GCC_PCIE0_PIPE_ARES] = { 0x28058, 0 }, >> + [GCC_PCIE1_AHB_ARES] = { 0x29058, 7 }, >> + [GCC_PCIE1_AUX_ARES] = { 0x29058, 6 }, >> + [GCC_PCIE1_AXI_M_ARES] = { 0x29058, 5 }, >> + [GCC_PCIE1_AXI_M_STICKY_ARES] = { 0x29058, 4 }, >> + [GCC_PCIE1_AXI_S_ARES] = { 0x29058, 3 }, >> + [GCC_PCIE1_AXI_S_STICKY_ARES] = { 0x29058, 2 }, >> + [GCC_PCIE1_CORE_STICKY_ARES] = { 0x29058, 1 }, >> + [GCC_PCIE1_PIPE_ARES] = { 0x29058, 0 }, >> + [GCC_PCIE2_AHB_ARES] = { 0x2a058, 7 }, >> + [GCC_PCIE2_AUX_ARES] = { 0x2a058, 6 }, >> + [GCC_PCIE2_AXI_M_ARES] = { 0x2a058, 5 }, >> + [GCC_PCIE2_AXI_M_STICKY_ARES] = { 0x2a058, 4 }, >> + [GCC_PCIE2_AXI_S_ARES] = { 0x2a058, 3 }, >> + [GCC_PCIE2_AXI_S_STICKY_ARES] = { 0x2a058, 2 }, >> + [GCC_PCIE2_CORE_STICKY_ARES] = { 0x2a058, 1 }, >> + [GCC_PCIE2_PIPE_ARES] = { 0x2a058, 0 }, >> + [GCC_PCIE3_AHB_ARES] = { 0x2b058, 7 }, >> + [GCC_PCIE3_AUX_ARES] = { 0x2b058, 6 }, >> + [GCC_PCIE3_AXI_M_ARES] = { 0x2b058, 5 }, >> + [GCC_PCIE3_AXI_M_STICKY_ARES] = { 0x2b058, 4 }, >> + [GCC_PCIE3_AXI_S_ARES] = { 0x2b058, 3 }, >> + [GCC_PCIE3_AXI_S_STICKY_ARES] = { 0x2b058, 2 }, >> + [GCC_PCIE3_CORE_STICKY_ARES] = { 0x2b058, 1 }, >> + [GCC_PCIE3_PIPE_ARES] = { 0x2b058, 0 }, >> + [GCC_PCIE0_BCR] = { 0x28000, 0 }, >> + [GCC_PCIE0_LINK_DOWN_BCR] = { 0x28054, 0 }, >> + [GCC_PCIE0_PHY_BCR] = { 0x28060, 0 }, >> + [GCC_PCIE1_BCR] = { 0x29000, 0 }, >> + [GCC_PCIE1_LINK_DOWN_BCR] = { 0x29054, 0 }, >> + [GCC_PCIE1_PHY_BCR] = { 0x29060, 0 }, >> + [GCC_PCIE1PHY_PHY_BCR] = { 0x2905c, 0 }, >> + [GCC_PCIE2_BCR] = { 0x2a000, 0 }, >> + [GCC_PCIE2_LINK_DOWN_BCR] = { 0x2a054, 0 }, >> + [GCC_PCIE2_PHY_BCR] = { 0x2a060, 0 }, >> + [GCC_PCIE2PHY_PHY_BCR] = { 0x2a05c, 0 }, >> + [GCC_PCIE3_BCR] = { 0x2b000, 0 }, >> + [GCC_PCIE3_LINK_DOWN_BCR] = { 0x2b054, 0 }, >> + [GCC_PCIE3PHY_PHY_BCR] = { 0x2b05c, 0 }, >> + [GCC_PCIE3_PHY_BCR] = { 0x2b060, 0 }, >> + [GCC_PCNOC_BCR] = { 0x31000, 0 }, >> + [GCC_PCNOC_BUS_TIMEOUT0_BCR] = { 0x31030, 0 }, >> + [GCC_PCNOC_BUS_TIMEOUT1_BCR] = { 0x31038, 0 }, >> + [GCC_PCNOC_BUS_TIMEOUT2_BCR] = { 0x31040, 0 }, >> + [GCC_PCNOC_BUS_TIMEOUT3_BCR] = { 0x31048, 0 }, >> + [GCC_PCNOC_BUS_TIMEOUT4_BCR] = { 0x31050, 0 }, >> + [GCC_PCNOC_BUS_TIMEOUT5_BCR] = { 0x31058, 0 }, >> + [GCC_PCNOC_BUS_TIMEOUT6_BCR] = { 0x31060, 0 }, >> + [GCC_PCNOC_BUS_TIMEOUT7_BCR] = { 0x31068, 0 }, >> + [GCC_PCNOC_BUS_TIMEOUT8_BCR] = { 0x31070, 0 }, >> + [GCC_PCNOC_BUS_TIMEOUT9_BCR] = { 0x31078, 0 }, >> + [GCC_PCNOC_TBU_BCR] = { 0x12034, 0 }, >> + [GCC_PRNG_BCR] = { 0x13020, 0 }, >> + [GCC_Q6SS_DBG_ARES] = { 0x2506c, 4 }, >> + [GCC_Q6_AHB_ARES] = { 0x2506c, 3 }, >> + [GCC_Q6_AHB_S_ARES] = { 0x2506c, 2 }, >> + [GCC_Q6_AXIM2_ARES] = { 0x2506c, 1 }, >> + [GCC_Q6_AXIM_ARES] = { 0x2506c, 0 }, >> + [GCC_QDSS_BCR] = { 0x2d000, 0 }, >> + [GCC_QPIC_BCR] = { 0x32000, 0 }, >> + [GCC_QPIC_AHB_ARES] = { 0x3201c, 1 }, >> + [GCC_QPIC_ARES] = { 0x3201c, 0 }, >> + [GCC_QUSB2_0_PHY_BCR] = { 0x2c068, 0 }, >> + [GCC_RBCPR_BCR] = { 0x39000, 0 }, >> + [GCC_RBCPR_MX_BCR] = { 0x39014, 0 }, >> + [GCC_SDCC_BCR] = { 0x33000, 0 }, >> + [GCC_SEC_CTRL_BCR] = { 0x1a000, 0 }, >> + [GCC_SMMU_CFG_BCR] = { 0x1202c, 0 }, >> + [GCC_SNOC_BCR] = { 0x2e000, 0 }, >> + [GCC_SPDM_BCR] = { 0x36000, 0 }, >> + [GCC_TCSR_BCR] = { 0x3d000, 0 }, >> + [GCC_TLMM_BCR] = { 0x3e000, 0 }, >> + [GCC_TME_BCR] = { 0x10000, 0 }, >> + [GCC_UNIPHY0_BCR] = { 0x17044, 0 }, >> + [GCC_UNIPHY0_SYS_RESET] = { 0x17050, 0 }, >> + [GCC_UNIPHY0_AHB_RESET] = { 0x17050, 1 }, >> + [GCC_UNIPHY0_XPCS_RESET] = { 0x17050, 2 }, >> + [GCC_UNIPHY1_SYS_RESET] = { 0x17060, 0 }, >> + [GCC_UNIPHY1_AHB_RESET] = { 0x17060, 1 }, >> + [GCC_UNIPHY1_XPCS_RESET] = { 0x17060, 2 }, >> + [GCC_UNIPHY2_SYS_RESET] = { 0x17070, 0 }, >> + [GCC_UNIPHY2_AHB_RESET] = { 0x17070, 1 }, >> + [GCC_UNIPHY2_XPCS_RESET] = { 0x17070, 2 }, >> + [GCC_UNIPHY1_BCR] = { 0x17054, 0 }, >> + [GCC_UNIPHY2_BCR] = { 0x17064, 0 }, >> + [GCC_USB0_PHY_BCR] = { 0x2c06c, 0 }, >> + [GCC_USB3PHY_0_PHY_BCR] = { 0x2c070, 0 }, >> + [GCC_USB_BCR] = { 0x2c000, 0 }, >> + [GCC_USB_MISC_RESET] = { 0x2c064, 0 }, >> + [GCC_WCSSAON_RESET] = { 0x25074, 0 }, >> + [GCC_WCSS_ACMT_ARES] = { 0x25070, 5 }, >> + [GCC_WCSS_AHB_S_ARES] = { 0x25070, 4 }, >> + [GCC_WCSS_AXI_M_ARES] = { 0x25070, 3 }, >> + [GCC_WCSS_BCR] = { 0x18004, 0 }, >> + [GCC_WCSS_DBG_ARES] = { 0x25070, 2 }, >> + [GCC_WCSS_DBG_BDG_ARES] = { 0x25070, 1 }, >> + [GCC_WCSS_ECAHB_ARES] = { 0x25070, 0 }, >> + [GCC_WCSS_Q6_BCR] = { 0x18000, 0 }, >> + [GCC_WCSS_Q6_TBU_BCR] = { 0x12054, 0 }, >> +}; >> + >> +static const struct of_device_id gcc_ipq9574_match_table[] = { >> + { .compatible = "qcom,ipq9574-gcc" }, >> + { } >> +}; >> +MODULE_DEVICE_TABLE(of, gcc_ipq9574_match_table); >> + >> +static const struct regmap_config gcc_ipq9574_regmap_config = { >> + .reg_bits = 32, >> + .reg_stride = 4, >> + .val_bits = 32, >> + .max_register = 0x7fffc, >> + .fast_io = true, >> +}; >> + >> +static const struct qcom_cc_desc gcc_ipq9574_desc = { >> + .config = &gcc_ipq9574_regmap_config, >> + .clks = gcc_ipq9574_clks, >> + .num_clks = ARRAY_SIZE(gcc_ipq9574_clks), >> + .resets = gcc_ipq9574_resets, >> + .num_resets = ARRAY_SIZE(gcc_ipq9574_resets), >> + .clk_hws = gcc_ipq9574_hws, >> + .num_clk_hws = ARRAY_SIZE(gcc_ipq9574_hws), >> +}; >> + >> +static int gcc_ipq9574_probe(struct platform_device *pdev) >> +{ >> + struct regmap *regmap; >> + struct qcom_cc_desc ipq9574_desc = gcc_ipq9574_desc; >> + >> + regmap = qcom_cc_map(pdev, &ipq9574_desc); >> + if (IS_ERR(regmap)) >> + return PTR_ERR(regmap); >> + >> + return qcom_cc_really_probe(pdev, &ipq9574_desc, regmap); >> +} >> + >> +static struct platform_driver gcc_ipq9574_driver = { >> + .probe = gcc_ipq9574_probe, >> + .driver = { >> + .name = "qcom,gcc-ipq9574", >> + .of_match_table = gcc_ipq9574_match_table, >> + }, >> +}; >> + >> +static int __init gcc_ipq9574_init(void) >> +{ >> + return platform_driver_register(&gcc_ipq9574_driver); >> +} >> +core_initcall(gcc_ipq9574_init); >> + >> +static void __exit gcc_ipq9574_exit(void) >> +{ >> + platform_driver_unregister(&gcc_ipq9574_driver); >> +} >> +module_exit(gcc_ipq9574_exit); >> + >> +MODULE_DESCRIPTION("Qualcomm Technologies, Inc. GCC IPQ9574 Driver"); >> +MODULE_LICENSE("GPL"); Best Regards, Devi Priya
On 1/26/2023 5:10 AM, Konrad Dybcio wrote: > > > On 25.01.2023 12:12, Devi Priya wrote: >> >> >> On 1/24/2023 8:44 PM, Krzysztof Kozlowski wrote: >>> On 24/01/2023 15:15, devi priya wrote: >>>> From: Poovendhan Selvaraj <quic_poovendh@quicinc.com> >>>> >>>> Add initial device tree support for Qualcomm IPQ9574 SoC >>>> and AL02 board >>>> >>>> Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> >>>> Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> >>>> Co-developed-by: devi priya <quic_devipriy@quicinc.com> >>>> Signed-off-by: devi priya <quic_devipriy@quicinc.com> >>>> Signed-off-by: Poovendhan Selvaraj <quic_poovendh@quicinc.com> >>>> --- >>>> arch/arm64/boot/dts/qcom/Makefile | 1 + >>>> arch/arm64/boot/dts/qcom/ipq9574-al02-c7.dts | 78 +++++ >>>> arch/arm64/boot/dts/qcom/ipq9574.dtsi | 285 +++++++++++++++++++ >>>> 3 files changed, 364 insertions(+) >>>> create mode 100644 arch/arm64/boot/dts/qcom/ipq9574-al02-c7.dts >>>> create mode 100644 arch/arm64/boot/dts/qcom/ipq9574.dtsi >>>> >>>> diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile >>>> index 3e79496292e7..872c62028a0b 100644 >>>> --- a/arch/arm64/boot/dts/qcom/Makefile >>>> +++ b/arch/arm64/boot/dts/qcom/Makefile >>>> @@ -7,6 +7,7 @@ dtb-$(CONFIG_ARCH_QCOM) += ipq6018-cp01-c1.dtb >>>> dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk01.dtb >>>> dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk10-c1.dtb >>>> dtb-$(CONFIG_ARCH_QCOM) += ipq8074-hk10-c2.dtb >>>> +dtb-$(CONFIG_ARCH_QCOM) += ipq9574-al02-c7.dtb >>>> dtb-$(CONFIG_ARCH_QCOM) += msm8916-alcatel-idol347.dtb >>> >>> This does not match current tree, so I could not apply it for tests. I >>> think you based it on a bit older version. >>> >> The patch series is based on Linux 6.2-rc1 and not the qcom/for-next branch. > Linux 6.2-rc1 is very old already and Bjorn has already picked > tens of patches atop it, so yours will not apply unless you > base it on qcom/for-next (or just linux-next for that matter). > Sure got it. Will post V3 based on linux-next > Konrad >>> Best regards, >>> Krzysztof >>> >> Best Regards, >> Devi Priya
On 1/25/2023 4:37 PM, Krzysztof Kozlowski wrote: > On 24/01/2023 15:15, devi priya wrote: >> Document the pinctrl driver for IPQ9574 >> >> Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> >> Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> >> Signed-off-by: devi priya <quic_devipriy@quicinc.com> >> --- >> .../bindings/pinctrl/qcom,ipq9574-tlmm.yaml | 135 ++++++++++++++++++ >> 1 file changed, 135 insertions(+) >> create mode 100644 Documentation/devicetree/bindings/pinctrl/qcom,ipq9574-tlmm.yaml >> >> diff --git a/Documentation/devicetree/bindings/pinctrl/qcom,ipq9574-tlmm.yaml b/Documentation/devicetree/bindings/pinctrl/qcom,ipq9574-tlmm.yaml >> new file mode 100644 >> index 000000000000..d736f0fb7835 >> --- /dev/null >> +++ b/Documentation/devicetree/bindings/pinctrl/qcom,ipq9574-tlmm.yaml >> @@ -0,0 +1,135 @@ >> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) >> +%YAML 1.2 >> +--- >> +$id: http://devicetree.org/schemas/pinctrl/qcom,ipq9574-tlmm.yaml# >> +$schema: http://devicetree.org/meta-schemas/core.yaml# >> + >> +title: Qualcomm Technologies, Inc. IPQ9574 TLMM block >> + >> +maintainers: >> + - Bjorn Andersson <andersson@kernel.org> >> + - Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> >> + >> +description: >> + Top Level Mode Multiplexer pin controller in Qualcomm IPQ9574 SoC. >> + >> +properties: >> + compatible: >> + const: qcom,ipq9574-tlmm >> + >> + reg: >> + maxItems: 1 >> + >> + interrupts: true > > Also - missing maxItems. > > I think you based your patches on some older version, so you might miss > here changes we did recently. Sure, will rebase it on linux-next and post V3 > > Best regards, > Krzysztof > Best Regards, Devi Priya
On 1/25/2023 2:34 PM, Kathiravan Thirumoorthy wrote: > > On 1/24/2023 7:45 PM, devi priya wrote: >> Add clock and reset ID definitions for ipq9574 >> >> Co-developed-by: Anusha Rao <quic_anusha@quicinc.com> >> Signed-off-by: Anusha Rao <quic_anusha@quicinc.com> >> Signed-off-by: devi priya <quic_devipriy@quicinc.com> >> --- >> .../bindings/clock/qcom,gcc-other.yaml | 39 +++- >> include/dt-bindings/clock/qcom,ipq9574-gcc.h | 213 ++++++++++++++++++ >> include/dt-bindings/reset/qcom,ipq9574-gcc.h | 164 ++++++++++++++ >> 3 files changed, 413 insertions(+), 3 deletions(-) >> create mode 100644 include/dt-bindings/clock/qcom,ipq9574-gcc.h >> create mode 100644 include/dt-bindings/reset/qcom,ipq9574-gcc.h >> >> diff --git >> a/Documentation/devicetree/bindings/clock/qcom,gcc-other.yaml >> b/Documentation/devicetree/bindings/clock/qcom,gcc-other.yaml >> index 2e8acca64af1..b8de54b25c2a 100644 >> --- a/Documentation/devicetree/bindings/clock/qcom,gcc-other.yaml >> +++ b/Documentation/devicetree/bindings/clock/qcom,gcc-other.yaml >> @@ -18,19 +18,19 @@ description: | >> include/dt-bindings/clock/qcom,gcc-ipq4019.h >> include/dt-bindings/clock/qcom,gcc-ipq6018.h >> include/dt-bindings/reset/qcom,gcc-ipq6018.h >> + include/dt-bindings/clock/qcom,ipq9574-gcc.h >> + include/dt-bindings/reset/qcom,ipq9574-gcc.h >> include/dt-bindings/clock/qcom,gcc-msm8953.h >> include/dt-bindings/clock/qcom,gcc-mdm9607.h >> include/dt-bindings/clock/qcom,gcc-mdm9615.h >> include/dt-bindings/reset/qcom,gcc-mdm9615.h >> -allOf: >> - - $ref: qcom,gcc.yaml# >> - >> properties: >> compatible: >> enum: >> - qcom,gcc-ipq4019 >> - qcom,gcc-ipq6018 >> + - qcom,ipq9574-gcc >> - qcom,gcc-mdm9607 >> - qcom,gcc-msm8953 >> - qcom,gcc-mdm9615 >> @@ -38,6 +38,39 @@ properties: >> required: >> - compatible >> +allOf: >> + - $ref: qcom,gcc.yaml# >> + >> + - if: >> + properties: >> + compatible: >> + contains: >> + enum: >> + - qcom,ipq9574-gcc >> + then: >> + properties: >> + clocks: >> + items: >> + - description: Board XO source >> + - description: Sleep clock source >> + - description: Bias PLL ubi clock source >> + - description: PCIE30 PHY0 pipe clock source >> + - description: PCIE30 PHY1 pipe clock source >> + - description: PCIE30 PHY2 pipe clock source >> + - description: PCIE30 PHY3 pipe clock source >> + - description: USB3 PHY pipe clock source >> + >> + clock-names: >> + items: >> + - const: xo >> + - const: sleep_clk >> + - const: bias_pll_ubi_nc_clk >> + - const: pcie30_phy0_pipe_clk >> + - const: pcie30_phy1_pipe_clk >> + - const: pcie30_phy2_pipe_clk >> + - const: pcie30_phy3_pipe_clk >> + - const: usb3phy_0_cc_pipe_clk > > How about creating a separate binding for IPQ9574 ? Looks like recently > some bindings are separated out to individual files. > Yeah, sure. will create a separate binding >> + >> unevaluatedProperties: false >> examples: >> diff --git a/include/dt-bindings/clock/qcom,ipq9574-gcc.h >> b/include/dt-bindings/clock/qcom,ipq9574-gcc.h >> new file mode 100644 >> index 000000000000..feedfdd5e00a >> --- /dev/null >> +++ b/include/dt-bindings/clock/qcom,ipq9574-gcc.h >> @@ -0,0 +1,213 @@ >> +/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) */ >> +/* >> + * Copyright (c) 2018-2023 The Linux Foundation. All rights reserved. >> + */ >> + >> +#ifndef _DT_BINDINGS_CLOCK_IPQ_GCC_9048_H >> +#define _DT_BINDINGS_CLOCK_IPQ_GCC_9048_H >> + >> +#define GPLL0_MAIN 0 >> +#define GPLL0 1 >> +#define GPLL2_MAIN 2 >> +#define GPLL2 3 >> +#define GPLL4_MAIN 4 >> +#define GPLL4 5 >> +#define GCC_SLEEP_CLK_SRC 6 >> +#define APSS_AHB_CLK_SRC 7 >> +#define APSS_AXI_CLK_SRC 8 >> +#define BLSP1_QUP1_I2C_APPS_CLK_SRC 9 >> +#define BLSP1_QUP1_SPI_APPS_CLK_SRC 10 >> +#define BLSP1_QUP2_I2C_APPS_CLK_SRC 11 >> +#define BLSP1_QUP2_SPI_APPS_CLK_SRC 12 >> +#define BLSP1_QUP3_I2C_APPS_CLK_SRC 13 >> +#define BLSP1_QUP3_SPI_APPS_CLK_SRC 14 >> +#define BLSP1_QUP4_I2C_APPS_CLK_SRC 15 >> +#define BLSP1_QUP4_SPI_APPS_CLK_SRC 16 >> +#define BLSP1_QUP5_I2C_APPS_CLK_SRC 17 >> +#define BLSP1_QUP5_SPI_APPS_CLK_SRC 18 >> +#define BLSP1_QUP6_I2C_APPS_CLK_SRC 19 >> +#define BLSP1_QUP6_SPI_APPS_CLK_SRC 20 >> +#define BLSP1_UART1_APPS_CLK_SRC 21 >> +#define BLSP1_UART2_APPS_CLK_SRC 22 >> +#define BLSP1_UART3_APPS_CLK_SRC 23 >> +#define BLSP1_UART4_APPS_CLK_SRC 24 >> +#define BLSP1_UART5_APPS_CLK_SRC 25 >> +#define BLSP1_UART6_APPS_CLK_SRC 26 >> +#define GCC_APSS_AHB_CLK 27 >> +#define GCC_APSS_AXI_CLK 28 >> +#define GCC_BLSP1_QUP1_I2C_APPS_CLK 29 >> +#define GCC_BLSP1_QUP1_SPI_APPS_CLK 30 >> +#define GCC_BLSP1_QUP2_I2C_APPS_CLK 31 >> +#define GCC_BLSP1_QUP2_SPI_APPS_CLK 32 >> +#define GCC_BLSP1_QUP3_I2C_APPS_CLK 33 >> +#define GCC_BLSP1_QUP3_SPI_APPS_CLK 34 >> +#define GCC_BLSP1_QUP4_I2C_APPS_CLK 35 >> +#define GCC_BLSP1_QUP4_SPI_APPS_CLK 36 >> +#define GCC_BLSP1_QUP5_I2C_APPS_CLK 37 >> +#define GCC_BLSP1_QUP5_SPI_APPS_CLK 38 >> +#define GCC_BLSP1_QUP6_I2C_APPS_CLK 39 >> +#define GCC_BLSP1_QUP6_SPI_APPS_CLK 40 >> +#define GCC_BLSP1_UART1_APPS_CLK 41 >> +#define GCC_BLSP1_UART2_APPS_CLK 42 >> +#define GCC_BLSP1_UART3_APPS_CLK 43 >> +#define GCC_BLSP1_UART4_APPS_CLK 44 >> +#define GCC_BLSP1_UART5_APPS_CLK 45 >> +#define GCC_BLSP1_UART6_APPS_CLK 46 >> +#define PCIE0_AXI_M_CLK_SRC 47 >> +#define GCC_PCIE0_AXI_M_CLK 48 >> +#define PCIE1_AXI_M_CLK_SRC 49 >> +#define GCC_PCIE1_AXI_M_CLK 50 >> +#define PCIE2_AXI_M_CLK_SRC 51 >> +#define GCC_PCIE2_AXI_M_CLK 52 >> +#define PCIE3_AXI_M_CLK_SRC 53 >> +#define GCC_PCIE3_AXI_M_CLK 54 >> +#define PCIE0_AXI_S_CLK_SRC 55 >> +#define GCC_PCIE0_AXI_S_BRIDGE_CLK 56 >> +#define GCC_PCIE0_AXI_S_CLK 57 >> +#define PCIE1_AXI_S_CLK_SRC 58 >> +#define GCC_PCIE1_AXI_S_BRIDGE_CLK 59 >> +#define GCC_PCIE1_AXI_S_CLK 60 >> +#define PCIE2_AXI_S_CLK_SRC 61 >> +#define GCC_PCIE2_AXI_S_BRIDGE_CLK 62 >> +#define GCC_PCIE2_AXI_S_CLK 63 >> +#define PCIE3_AXI_S_CLK_SRC 64 >> +#define GCC_PCIE3_AXI_S_BRIDGE_CLK 65 >> +#define GCC_PCIE3_AXI_S_CLK 66 >> +#define PCIE0_PIPE_CLK_SRC 67 >> +#define PCIE1_PIPE_CLK_SRC 68 >> +#define PCIE2_PIPE_CLK_SRC 69 >> +#define PCIE3_PIPE_CLK_SRC 70 >> +#define PCIE_AUX_CLK_SRC 71 >> +#define GCC_PCIE0_AUX_CLK 72 >> +#define GCC_PCIE1_AUX_CLK 73 >> +#define GCC_PCIE2_AUX_CLK 74 >> +#define GCC_PCIE3_AUX_CLK 75 >> +#define PCIE0_RCHNG_CLK_SRC 76 >> +#define GCC_PCIE0_RCHNG_CLK 77 >> +#define PCIE1_RCHNG_CLK_SRC 78 >> +#define GCC_PCIE1_RCHNG_CLK 79 >> +#define PCIE2_RCHNG_CLK_SRC 80 >> +#define GCC_PCIE2_RCHNG_CLK 81 >> +#define PCIE3_RCHNG_CLK_SRC 82 >> +#define GCC_PCIE3_RCHNG_CLK 83 >> +#define GCC_PCIE0_AHB_CLK 84 >> +#define GCC_PCIE1_AHB_CLK 85 >> +#define GCC_PCIE2_AHB_CLK 86 >> +#define GCC_PCIE3_AHB_CLK 87 >> +#define USB0_AUX_CLK_SRC 88 >> +#define GCC_USB0_AUX_CLK 89 >> +#define USB0_MASTER_CLK_SRC 90 >> +#define GCC_USB0_MASTER_CLK 91 >> +#define GCC_SNOC_USB_CLK 92 >> +#define GCC_ANOC_USB_AXI_CLK 93 >> +#define USB0_MOCK_UTMI_CLK_SRC 94 >> +#define USB0_MOCK_UTMI_DIV_CLK_SRC 95 >> +#define GCC_USB0_MOCK_UTMI_CLK 96 >> +#define USB0_PIPE_CLK_SRC 97 >> +#define GCC_USB0_PHY_CFG_AHB_CLK 98 >> +#define SDCC1_APPS_CLK_SRC 99 >> +#define GCC_SDCC1_APPS_CLK 100 >> +#define SDCC1_ICE_CORE_CLK_SRC 101 >> +#define GCC_SDCC1_ICE_CORE_CLK 102 >> +#define GCC_SDCC1_AHB_CLK 103 >> +#define PCNOC_BFDCD_CLK_SRC 104 >> +#define GCC_NSSCFG_CLK 105 >> +#define GCC_NSSNOC_NSSCC_CLK 106 >> +#define GCC_NSSCC_CLK 107 >> +#define GCC_NSSNOC_PCNOC_1_CLK 108 >> +#define GCC_QDSS_DAP_AHB_CLK 109 >> +#define GCC_QDSS_CFG_AHB_CLK 110 >> +#define GCC_QPIC_AHB_CLK 111 >> +#define GCC_QPIC_CLK 112 >> +#define GCC_BLSP1_AHB_CLK 113 >> +#define GCC_MDIO_AHB_CLK 114 >> +#define GCC_PRNG_AHB_CLK 115 >> +#define GCC_UNIPHY0_AHB_CLK 116 >> +#define GCC_UNIPHY1_AHB_CLK 117 >> +#define GCC_UNIPHY2_AHB_CLK 118 >> +#define GCC_CMN_12GPLL_AHB_CLK 119 >> +#define GCC_CMN_12GPLL_APU_CLK 120 >> +#define SYSTEM_NOC_BFDCD_CLK_SRC 121 >> +#define GCC_NSSNOC_SNOC_CLK 122 >> +#define GCC_NSSNOC_SNOC_1_CLK 123 >> +#define GCC_QDSS_ETR_USB_CLK 124 >> +#define WCSS_AHB_CLK_SRC 125 >> +#define GCC_Q6_AHB_CLK 126 >> +#define GCC_Q6_AHB_S_CLK 127 >> +#define GCC_WCSS_ECAHB_CLK 128 >> +#define GCC_WCSS_ACMT_CLK 129 >> +#define GCC_SYS_NOC_WCSS_AHB_CLK 130 >> +#define WCSS_AXI_M_CLK_SRC 131 >> +#define GCC_ANOC_WCSS_AXI_M_CLK 132 >> +#define QDSS_AT_CLK_SRC 133 >> +#define GCC_Q6SS_ATBM_CLK 134 >> +#define GCC_WCSS_DBG_IFC_ATB_CLK 135 >> +#define GCC_NSSNOC_ATB_CLK 136 >> +#define GCC_QDSS_AT_CLK 137 >> +#define GCC_SYS_NOC_AT_CLK 138 >> +#define GCC_PCNOC_AT_CLK 139 >> +#define GCC_USB0_EUD_AT_CLK 140 >> +#define GCC_QDSS_EUD_AT_CLK 141 >> +#define QDSS_STM_CLK_SRC 142 >> +#define GCC_QDSS_STM_CLK 143 >> +#define GCC_SYS_NOC_QDSS_STM_AXI_CLK 144 >> +#define QDSS_TRACECLKIN_CLK_SRC 145 >> +#define GCC_QDSS_TRACECLKIN_CLK 146 >> +#define QDSS_TSCTR_CLK_SRC 147 >> +#define GCC_Q6_TSCTR_1TO2_CLK 148 >> +#define GCC_WCSS_DBG_IFC_NTS_CLK 149 >> +#define GCC_QDSS_TSCTR_DIV2_CLK 150 >> +#define GCC_QDSS_TS_CLK 151 >> +#define GCC_QDSS_TSCTR_DIV4_CLK 152 >> +#define GCC_NSS_TS_CLK 153 >> +#define GCC_QDSS_TSCTR_DIV8_CLK 154 >> +#define GCC_QDSS_TSCTR_DIV16_CLK 155 >> +#define GCC_Q6SS_PCLKDBG_CLK 156 >> +#define GCC_Q6SS_TRIG_CLK 157 >> +#define GCC_WCSS_DBG_IFC_APB_CLK 158 >> +#define GCC_WCSS_DBG_IFC_DAPBUS_CLK 159 >> +#define GCC_QDSS_DAP_CLK 160 >> +#define GCC_QDSS_APB2JTAG_CLK 161 >> +#define GCC_QDSS_TSCTR_DIV3_CLK 162 >> +#define QPIC_IO_MACRO_CLK_SRC 163 >> +#define GCC_QPIC_IO_MACRO_CLK 164 >> +#define Q6_AXI_CLK_SRC 165 >> +#define GCC_Q6_AXIM_CLK 166 >> +#define GCC_WCSS_Q6_TBU_CLK 167 >> +#define GCC_MEM_NOC_Q6_AXI_CLK 168 >> +#define Q6_AXIM2_CLK_SRC 169 >> +#define NSSNOC_MEMNOC_BFDCD_CLK_SRC 170 >> +#define GCC_NSSNOC_MEMNOC_CLK 171 >> +#define GCC_NSSNOC_MEM_NOC_1_CLK 172 >> +#define GCC_NSS_TBU_CLK 173 >> +#define GCC_MEM_NOC_NSSNOC_CLK 174 >> +#define LPASS_AXIM_CLK_SRC 175 >> +#define LPASS_SWAY_CLK_SRC 176 >> +#define ADSS_PWM_CLK_SRC 177 >> +#define GCC_ADSS_PWM_CLK 178 >> +#define GP1_CLK_SRC 179 >> +#define GP2_CLK_SRC 180 >> +#define GP3_CLK_SRC 181 >> +#define DDRSS_SMS_SLOW_CLK_SRC 182 >> +#define GCC_XO_CLK_SRC 183 >> +#define GCC_XO_CLK 184 >> +#define GCC_NSSNOC_QOSGEN_REF_CLK 185 >> +#define GCC_NSSNOC_TIMEOUT_REF_CLK 186 >> +#define GCC_XO_DIV4_CLK 187 >> +#define GCC_UNIPHY0_SYS_CLK 188 >> +#define GCC_UNIPHY1_SYS_CLK 189 >> +#define GCC_UNIPHY2_SYS_CLK 190 >> +#define GCC_CMN_12GPLL_SYS_CLK 191 >> +#define GCC_NSSNOC_XO_DCD_CLK 192 >> +#define GCC_Q6SS_BOOT_CLK 193 >> +#define UNIPHY_SYS_CLK_SRC 194 >> +#define NSS_TS_CLK_SRC 195 >> +#define GCC_ANOC_PCIE0_1LANE_M_CLK 196 >> +#define GCC_ANOC_PCIE1_1LANE_M_CLK 197 >> +#define GCC_ANOC_PCIE2_2LANE_M_CLK 198 >> +#define GCC_ANOC_PCIE3_2LANE_M_CLK 199 >> +#define GCC_SNOC_PCIE0_1LANE_S_CLK 200 >> +#define GCC_SNOC_PCIE1_1LANE_S_CLK 201 >> +#define GCC_SNOC_PCIE2_2LANE_S_CLK 202 >> +#define GCC_SNOC_PCIE3_2LANE_S_CLK 203 >> +#endif >> diff --git a/include/dt-bindings/reset/qcom,ipq9574-gcc.h >> b/include/dt-bindings/reset/qcom,ipq9574-gcc.h >> new file mode 100644 >> index 000000000000..a11adbda45ec >> --- /dev/null >> +++ b/include/dt-bindings/reset/qcom,ipq9574-gcc.h >> @@ -0,0 +1,164 @@ >> +/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) */ >> +/* >> + * Copyright (c) 2018-2023, The Linux Foundation. All rights reserved. >> + */ >> + >> +#ifndef _DT_BINDINGS_RESET_IPQ_GCC_9048_H >> +#define _DT_BINDINGS_RESET_IPQ_GCC_9048_H >> + >> +#define GCC_ADSS_BCR 0 >> +#define GCC_APC0_VOLTAGE_DROOP_DETECTOR_BCR 1 >> +#define GCC_BLSP1_BCR 2 >> +#define GCC_BLSP1_QUP1_BCR 3 >> +#define GCC_BLSP1_QUP2_BCR 4 >> +#define GCC_BLSP1_QUP3_BCR 5 >> +#define GCC_BLSP1_QUP4_BCR 6 >> +#define GCC_BLSP1_QUP5_BCR 7 >> +#define GCC_BLSP1_QUP6_BCR 8 >> +#define GCC_BLSP1_UART1_BCR 9 >> +#define GCC_BLSP1_UART2_BCR 10 >> +#define GCC_BLSP1_UART3_BCR 11 >> +#define GCC_BLSP1_UART4_BCR 12 >> +#define GCC_BLSP1_UART5_BCR 13 >> +#define GCC_BLSP1_UART6_BCR 14 >> +#define GCC_BOOT_ROM_BCR 15 >> +#define GCC_MDIO_BCR 16 >> +#define GCC_NSS_BCR 17 >> +#define GCC_NSS_TBU_BCR 18 >> +#define GCC_PCIE0_BCR 19 >> +#define GCC_PCIE0_LINK_DOWN_BCR 20 >> +#define GCC_PCIE0_PHY_BCR 21 >> +#define GCC_PCIE0PHY_PHY_BCR 22 >> +#define GCC_PCIE1_BCR 23 >> +#define GCC_PCIE1_LINK_DOWN_BCR 24 >> +#define GCC_PCIE1_PHY_BCR 25 >> +#define GCC_PCIE1PHY_PHY_BCR 26 >> +#define GCC_PCIE2_BCR 27 >> +#define GCC_PCIE2_LINK_DOWN_BCR 28 >> +#define GCC_PCIE2_PHY_BCR 29 >> +#define GCC_PCIE2PHY_PHY_BCR 30 >> +#define GCC_PCIE3_BCR 31 >> +#define GCC_PCIE3_LINK_DOWN_BCR 32 >> +#define GCC_PCIE3_PHY_BCR 33 >> +#define GCC_PCIE3PHY_PHY_BCR 34 >> +#define GCC_PRNG_BCR 35 >> +#define GCC_QUSB2_0_PHY_BCR 36 >> +#define GCC_SDCC_BCR 37 >> +#define GCC_TLMM_BCR 38 >> +#define GCC_UNIPHY0_BCR 39 >> +#define GCC_UNIPHY1_BCR 40 >> +#define GCC_UNIPHY2_BCR 41 >> +#define GCC_USB0_PHY_BCR 42 >> +#define GCC_USB3PHY_0_PHY_BCR 43 >> +#define GCC_USB_BCR 44 >> +#define GCC_ANOC0_TBU_BCR 45 >> +#define GCC_ANOC1_TBU_BCR 46 >> +#define GCC_ANOC_BCR 47 >> +#define GCC_APSS_TCU_BCR 48 >> +#define GCC_CMN_BLK_BCR 49 >> +#define GCC_CMN_BLK_AHB_ARES 50 >> +#define GCC_CMN_BLK_SYS_ARES 51 >> +#define GCC_CMN_BLK_APU_ARES 52 >> +#define GCC_DCC_BCR 53 >> +#define GCC_DDRSS_BCR 54 >> +#define GCC_IMEM_BCR 55 >> +#define GCC_LPASS_BCR 56 >> +#define GCC_MPM_BCR 57 >> +#define GCC_MSG_RAM_BCR 58 >> +#define GCC_NSSNOC_MEMNOC_1_ARES 59 >> +#define GCC_NSSNOC_PCNOC_1_ARES 60 >> +#define GCC_NSSNOC_SNOC_1_ARES 61 >> +#define GCC_NSSNOC_XO_DCD_ARES 62 >> +#define GCC_NSSNOC_TS_ARES 63 >> +#define GCC_NSSCC_ARES 64 >> +#define GCC_NSSNOC_NSSCC_ARES 65 >> +#define GCC_NSSNOC_ATB_ARES 66 >> +#define GCC_NSSNOC_MEMNOC_ARES 67 >> +#define GCC_NSSNOC_QOSGEN_REF_ARES 68 >> +#define GCC_NSSNOC_SNOC_ARES 69 >> +#define GCC_NSSNOC_TIMEOUT_REF_ARES 70 >> +#define GCC_NSS_CFG_ARES 71 >> +#define GCC_UBI0_DBG_ARES 72 >> +#define GCC_PCIE0_AHB_ARES 73 >> +#define GCC_PCIE0_AUX_ARES 74 >> +#define GCC_PCIE0_AXI_M_ARES 75 >> +#define GCC_PCIE0_AXI_M_STICKY_ARES 76 >> +#define GCC_PCIE0_AXI_S_ARES 77 >> +#define GCC_PCIE0_AXI_S_STICKY_ARES 78 >> +#define GCC_PCIE0_CORE_STICKY_ARES 79 >> +#define GCC_PCIE0_PIPE_ARES 80 >> +#define GCC_PCIE1_AHB_ARES 81 >> +#define GCC_PCIE1_AUX_ARES 82 >> +#define GCC_PCIE1_AXI_M_ARES 83 >> +#define GCC_PCIE1_AXI_M_STICKY_ARES 84 >> +#define GCC_PCIE1_AXI_S_ARES 85 >> +#define GCC_PCIE1_AXI_S_STICKY_ARES 86 >> +#define GCC_PCIE1_CORE_STICKY_ARES 87 >> +#define GCC_PCIE1_PIPE_ARES 88 >> +#define GCC_PCIE2_AHB_ARES 89 >> +#define GCC_PCIE2_AUX_ARES 90 >> +#define GCC_PCIE2_AXI_M_ARES 91 >> +#define GCC_PCIE2_AXI_M_STICKY_ARES 92 >> +#define GCC_PCIE2_AXI_S_ARES 93 >> +#define GCC_PCIE2_AXI_S_STICKY_ARES 94 >> +#define GCC_PCIE2_CORE_STICKY_ARES 95 >> +#define GCC_PCIE2_PIPE_ARES 96 >> +#define GCC_PCIE3_AHB_ARES 97 >> +#define GCC_PCIE3_AUX_ARES 98 >> +#define GCC_PCIE3_AXI_M_ARES 99 >> +#define GCC_PCIE3_AXI_M_STICKY_ARES 100 >> +#define GCC_PCIE3_AXI_S_ARES 101 >> +#define GCC_PCIE3_AXI_S_STICKY_ARES 102 >> +#define GCC_PCIE3_CORE_STICKY_ARES 103 >> +#define GCC_PCIE3_PIPE_ARES 104 >> +#define GCC_PCNOC_BCR 105 >> +#define GCC_PCNOC_BUS_TIMEOUT0_BCR 106 >> +#define GCC_PCNOC_BUS_TIMEOUT1_BCR 107 >> +#define GCC_PCNOC_BUS_TIMEOUT2_BCR 108 >> +#define GCC_PCNOC_BUS_TIMEOUT3_BCR 109 >> +#define GCC_PCNOC_BUS_TIMEOUT4_BCR 110 >> +#define GCC_PCNOC_BUS_TIMEOUT5_BCR 111 >> +#define GCC_PCNOC_BUS_TIMEOUT6_BCR 112 >> +#define GCC_PCNOC_BUS_TIMEOUT7_BCR 113 >> +#define GCC_PCNOC_BUS_TIMEOUT8_BCR 114 >> +#define GCC_PCNOC_BUS_TIMEOUT9_BCR 115 >> +#define GCC_PCNOC_TBU_BCR 116 >> +#define GCC_Q6SS_DBG_ARES 117 >> +#define GCC_Q6_AHB_ARES 118 >> +#define GCC_Q6_AHB_S_ARES 119 >> +#define GCC_Q6_AXIM2_ARES 120 >> +#define GCC_Q6_AXIM_ARES 121 >> +#define GCC_QDSS_BCR 122 >> +#define GCC_QPIC_BCR 123 >> +#define GCC_QPIC_AHB_ARES 124 >> +#define GCC_QPIC_ARES 125 >> +#define GCC_RBCPR_BCR 126 >> +#define GCC_RBCPR_MX_BCR 127 >> +#define GCC_SEC_CTRL_BCR 128 >> +#define GCC_SMMU_CFG_BCR 129 >> +#define GCC_SNOC_BCR 130 >> +#define GCC_SPDM_BCR 131 >> +#define GCC_TME_BCR 132 >> +#define GCC_UNIPHY0_SYS_RESET 133 >> +#define GCC_UNIPHY0_AHB_RESET 134 >> +#define GCC_UNIPHY0_XPCS_RESET 135 >> +#define GCC_UNIPHY1_SYS_RESET 136 >> +#define GCC_UNIPHY1_AHB_RESET 137 >> +#define GCC_UNIPHY1_XPCS_RESET 138 >> +#define GCC_UNIPHY2_SYS_RESET 139 >> +#define GCC_UNIPHY2_AHB_RESET 140 >> +#define GCC_UNIPHY2_XPCS_RESET 141 >> +#define GCC_USB_MISC_RESET 142 >> +#define GCC_WCSSAON_RESET 143 >> +#define GCC_WCSS_ACMT_ARES 144 >> +#define GCC_WCSS_AHB_S_ARES 145 >> +#define GCC_WCSS_AXI_M_ARES 146 >> +#define GCC_WCSS_BCR 147 >> +#define GCC_WCSS_DBG_ARES 148 >> +#define GCC_WCSS_DBG_BDG_ARES 149 >> +#define GCC_WCSS_ECAHB_ARES 150 >> +#define GCC_WCSS_Q6_BCR 151 >> +#define GCC_WCSS_Q6_TBU_BCR 152 >> +#define GCC_TCSR_BCR 153 >> + >> +#endif Best Regards, Devi Priya