aboutsummaryrefslogtreecommitdiffstats
path: root/recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc
diff options
context:
space:
mode:
Diffstat (limited to 'recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc')
-rw-r--r--recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0001-dt-bindings-interconnect-Add-Qualcomm-SM6115-NoC.patch297
-rw-r--r--recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0001-iommu-arm-smmu-qcom-Add-SM6115-MDSS-compatible.patch30
-rw-r--r--recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0002-interconnect-qcom-Add-SM6115-interconnect-provider-d.patch1495
3 files changed, 1822 insertions, 0 deletions
diff --git a/recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0001-dt-bindings-interconnect-Add-Qualcomm-SM6115-NoC.patch b/recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0001-dt-bindings-interconnect-Add-Qualcomm-SM6115-NoC.patch
new file mode 100644
index 0000000..94565eb
--- /dev/null
+++ b/recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0001-dt-bindings-interconnect-Add-Qualcomm-SM6115-NoC.patch
@@ -0,0 +1,297 @@
+From 658902913c7044ac5d56b14cea54e735a071fe41 Mon Sep 17 00:00:00 2001
+From: Konrad Dybcio <konrad.dybcio@linaro.org>
+Date: Wed, 29 Nov 2023 15:41:01 +0100
+Subject: [PATCH 1/2] dt-bindings: interconnect: Add Qualcomm SM6115 NoC
+
+Add bindings for Qualcomm SM6115 Network-On-Chip interconnect.
+
+Signed-off-by: Konrad Dybcio <konrad.dybcio@linaro.org>
+Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
+Link: https://lore.kernel.org/r/20231125-topic-6115icc-v3-1-bd8907b8cfd7@linaro.org
+Signed-off-by: Georgi Djakov <djakov@kernel.org>
+Upstream-Status: Backport [https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git 658902913c7044ac5d56b14cea54e735a071fe41]
+---
+ .../bindings/interconnect/qcom,sm6115.yaml | 152 ++++++++++++++++++
+ .../dt-bindings/interconnect/qcom,sm6115.h | 111 +++++++++++++
+ 2 files changed, 263 insertions(+)
+ create mode 100644 Documentation/devicetree/bindings/interconnect/qcom,sm6115.yaml
+ create mode 100644 include/dt-bindings/interconnect/qcom,sm6115.h
+
+diff --git a/Documentation/devicetree/bindings/interconnect/qcom,sm6115.yaml b/Documentation/devicetree/bindings/interconnect/qcom,sm6115.yaml
+new file mode 100644
+index 000000000000..14b1a0b08e73
+--- /dev/null
++++ b/Documentation/devicetree/bindings/interconnect/qcom,sm6115.yaml
+@@ -0,0 +1,152 @@
++# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
++%YAML 1.2
++---
++$id: http://devicetree.org/schemas/interconnect/qcom,sm6115.yaml#
++$schema: http://devicetree.org/meta-schemas/core.yaml#
++
++title: Qualcomm SM6115 Network-On-Chip interconnect
++
++maintainers:
++ - Konrad Dybcio <konradybcio@kernel.org>
++
++description:
++ The Qualcomm SM6115 interconnect providers support adjusting the
++ bandwidth requirements between the various NoC fabrics.
++
++properties:
++ compatible:
++ enum:
++ - qcom,sm6115-bimc
++ - qcom,sm6115-cnoc
++ - qcom,sm6115-snoc
++
++ reg:
++ maxItems: 1
++
++ clocks:
++ minItems: 1
++ maxItems: 4
++
++ clock-names:
++ minItems: 1
++ maxItems: 4
++
++# Child node's properties
++patternProperties:
++ '^interconnect-[a-z0-9]+$':
++ type: object
++ description:
++ The interconnect providers do not have a separate QoS register space,
++ but share parent's space.
++
++ $ref: qcom,rpm-common.yaml#
++
++ properties:
++ compatible:
++ enum:
++ - qcom,sm6115-clk-virt
++ - qcom,sm6115-mmrt-virt
++ - qcom,sm6115-mmnrt-virt
++
++ required:
++ - compatible
++
++ unevaluatedProperties: false
++
++required:
++ - compatible
++ - reg
++
++allOf:
++ - $ref: qcom,rpm-common.yaml#
++ - if:
++ properties:
++ compatible:
++ const: qcom,sm6115-cnoc
++
++ then:
++ properties:
++ clocks:
++ items:
++ - description: USB-NoC AXI clock
++
++ clock-names:
++ items:
++ - const: usb_axi
++
++ - if:
++ properties:
++ compatible:
++ const: qcom,sm6115-snoc
++
++ then:
++ properties:
++ clocks:
++ items:
++ - description: CPU-NoC AXI clock.
++ - description: UFS-NoC AXI clock.
++ - description: USB-NoC AXI clock.
++ - description: IPA clock.
++
++ clock-names:
++ items:
++ - const: cpu_axi
++ - const: ufs_axi
++ - const: usb_axi
++ - const: ipa
++
++ - if:
++ properties:
++ compatible:
++ enum:
++ - qcom,sm6115-bimc
++ - qcom,sm6115-clk-virt
++ - qcom,sm6115-mmrt-virt
++ - qcom,sm6115-mmnrt-virt
++
++ then:
++ properties:
++ clocks: false
++ clock-names: false
++
++unevaluatedProperties: false
++
++examples:
++ - |
++ #include <dt-bindings/clock/qcom,gcc-sm6115.h>
++ #include <dt-bindings/clock/qcom,rpmcc.h>
++
++ snoc: interconnect@1880000 {
++ compatible = "qcom,sm6115-snoc";
++ reg = <0x01880000 0x60200>;
++ clocks = <&gcc GCC_SYS_NOC_CPUSS_AHB_CLK>,
++ <&gcc GCC_SYS_NOC_UFS_PHY_AXI_CLK>,
++ <&gcc GCC_SYS_NOC_USB3_PRIM_AXI_CLK>,
++ <&rpmcc RPM_SMD_IPA_CLK>;
++ clock-names = "cpu_axi",
++ "ufs_axi",
++ "usb_axi",
++ "ipa";
++ #interconnect-cells = <1>;
++
++ qup_virt: interconnect-clk {
++ compatible = "qcom,sm6115-clk-virt";
++ #interconnect-cells = <1>;
++ };
++
++ mmnrt_virt: interconnect-mmnrt {
++ compatible = "qcom,sm6115-mmnrt-virt";
++ #interconnect-cells = <1>;
++ };
++
++ mmrt_virt: interconnect-mmrt {
++ compatible = "qcom,sm6115-mmrt-virt";
++ #interconnect-cells = <1>;
++ };
++ };
++
++ cnoc: interconnect@1900000 {
++ compatible = "qcom,sm6115-cnoc";
++ reg = <0x01900000 0x8200>;
++ #interconnect-cells = <1>;
++ };
+diff --git a/include/dt-bindings/interconnect/qcom,sm6115.h b/include/dt-bindings/interconnect/qcom,sm6115.h
+new file mode 100644
+index 000000000000..21090e585f05
+--- /dev/null
++++ b/include/dt-bindings/interconnect/qcom,sm6115.h
+@@ -0,0 +1,111 @@
++/* SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause */
++/*
++ * Copyright (c) 2020, The Linux Foundation. All rights reserved.
++ * Copyright (c) 2023, Linaro Limited
++ */
++
++#ifndef __DT_BINDINGS_INTERCONNECT_QCOM_SM6115_H
++#define __DT_BINDINGS_INTERCONNECT_QCOM_SM6115_H
++
++/* BIMC */
++#define MASTER_AMPSS_M0 0
++#define MASTER_SNOC_BIMC_RT 1
++#define MASTER_SNOC_BIMC_NRT 2
++#define SNOC_BIMC_MAS 3
++#define MASTER_GRAPHICS_3D 4
++#define MASTER_TCU_0 5
++#define SLAVE_EBI_CH0 6
++#define BIMC_SNOC_SLV 7
++
++/* CNOC */
++#define SNOC_CNOC_MAS 0
++#define MASTER_QDSS_DAP 1
++#define SLAVE_AHB2PHY_USB 2
++#define SLAVE_APSS_THROTTLE_CFG 3
++#define SLAVE_BIMC_CFG 4
++#define SLAVE_BOOT_ROM 5
++#define SLAVE_CAMERA_NRT_THROTTLE_CFG 6
++#define SLAVE_CAMERA_RT_THROTTLE_CFG 7
++#define SLAVE_CAMERA_CFG 8
++#define SLAVE_CLK_CTL 9
++#define SLAVE_RBCPR_CX_CFG 10
++#define SLAVE_RBCPR_MX_CFG 11
++#define SLAVE_CRYPTO_0_CFG 12
++#define SLAVE_DCC_CFG 13
++#define SLAVE_DDR_PHY_CFG 14
++#define SLAVE_DDR_SS_CFG 15
++#define SLAVE_DISPLAY_CFG 16
++#define SLAVE_DISPLAY_THROTTLE_CFG 17
++#define SLAVE_GPU_CFG 18
++#define SLAVE_GPU_THROTTLE_CFG 19
++#define SLAVE_HWKM_CORE 20
++#define SLAVE_IMEM_CFG 21
++#define SLAVE_IPA_CFG 22
++#define SLAVE_LPASS 23
++#define SLAVE_MAPSS 24
++#define SLAVE_MDSP_MPU_CFG 25
++#define SLAVE_MESSAGE_RAM 26
++#define SLAVE_CNOC_MSS 27
++#define SLAVE_PDM 28
++#define SLAVE_PIMEM_CFG 29
++#define SLAVE_PKA_CORE 30
++#define SLAVE_PMIC_ARB 31
++#define SLAVE_QDSS_CFG 32
++#define SLAVE_QM_CFG 33
++#define SLAVE_QM_MPU_CFG 34
++#define SLAVE_QPIC 35
++#define SLAVE_QUP_0 36
++#define SLAVE_RPM 37
++#define SLAVE_SDCC_1 38
++#define SLAVE_SDCC_2 39
++#define SLAVE_SECURITY 40
++#define SLAVE_SNOC_CFG 41
++#define SLAVE_TCSR 42
++#define SLAVE_TLMM 43
++#define SLAVE_USB3 44
++#define SLAVE_VENUS_CFG 45
++#define SLAVE_VENUS_THROTTLE_CFG 46
++#define SLAVE_VSENSE_CTRL_CFG 47
++#define SLAVE_SERVICE_CNOC 48
++
++/* SNOC */
++#define MASTER_CRYPTO_CORE0 0
++#define MASTER_SNOC_CFG 1
++#define MASTER_TIC 2
++#define MASTER_ANOC_SNOC 3
++#define BIMC_SNOC_MAS 4
++#define MASTER_PIMEM 5
++#define MASTER_QDSS_BAM 6
++#define MASTER_QPIC 7
++#define MASTER_QUP_0 8
++#define MASTER_IPA 9
++#define MASTER_QDSS_ETR 10
++#define MASTER_SDCC_1 11
++#define MASTER_SDCC_2 12
++#define MASTER_USB3 13
++#define SLAVE_APPSS 14
++#define SNOC_CNOC_SLV 15
++#define SLAVE_OCIMEM 16
++#define SLAVE_PIMEM 17
++#define SNOC_BIMC_SLV 18
++#define SLAVE_SERVICE_SNOC 19
++#define SLAVE_QDSS_STM 20
++#define SLAVE_TCU 21
++#define SLAVE_ANOC_SNOC 22
++
++/* CLK Virtual */
++#define MASTER_QUP_CORE_0 0
++#define SLAVE_QUP_CORE_0 1
++
++/* MMRT Virtual */
++#define MASTER_CAMNOC_HF 0
++#define MASTER_MDP_PORT0 1
++#define SLAVE_SNOC_BIMC_RT 2
++
++/* MMNRT Virtual */
++#define MASTER_CAMNOC_SF 0
++#define MASTER_VIDEO_P0 1
++#define MASTER_VIDEO_PROC 2
++#define SLAVE_SNOC_BIMC_NRT 3
++
++#endif
+--
+2.39.2
+
diff --git a/recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0001-iommu-arm-smmu-qcom-Add-SM6115-MDSS-compatible.patch b/recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0001-iommu-arm-smmu-qcom-Add-SM6115-MDSS-compatible.patch
new file mode 100644
index 0000000..6686e98
--- /dev/null
+++ b/recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0001-iommu-arm-smmu-qcom-Add-SM6115-MDSS-compatible.patch
@@ -0,0 +1,30 @@
+From 3b744008c1d08c25c9066206b8f4c3fb0006e9d0 Mon Sep 17 00:00:00 2001
+From: Konrad Dybcio <konrad.dybcio@linaro.org>
+Date: Wed, 29 Nov 2023 15:44:02 +0100
+Subject: [PATCH] iommu/arm-smmu-qcom: Add SM6115 MDSS compatible
+
+Add the SM6115 MDSS compatible to clients compatible list, as it also
+needs the workarounds.
+
+Signed-off-by: Konrad Dybcio <konrad.dybcio@linaro.org>
+Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
+Upstream-Status: Pending
+---
+ drivers/iommu/arm/arm-smmu/arm-smmu-qcom.c | 1 +
+ 1 file changed, 1 insertion(+)
+
+diff --git a/drivers/iommu/arm/arm-smmu/arm-smmu-qcom.c b/drivers/iommu/arm/arm-smmu/arm-smmu-qcom.c
+index fdabb4b3f7c0..db7c4c71dec1 100644
+--- a/drivers/iommu/arm/arm-smmu/arm-smmu-qcom.c
++++ b/drivers/iommu/arm/arm-smmu/arm-smmu-qcom.c
+@@ -254,6 +254,7 @@ static const struct of_device_id qcom_smmu_client_of_match[] __maybe_unused = {
+ { .compatible = "qcom,sc8280xp-mdss" },
+ { .compatible = "qcom,sdm845-mdss" },
+ { .compatible = "qcom,sdm845-mss-pil" },
++ { .compatible = "qcom,sm6115-mdss" },
+ { .compatible = "qcom,sm6350-mdss" },
+ { .compatible = "qcom,sm6375-mdss" },
+ { .compatible = "qcom,sm8150-mdss" },
+--
+2.39.2
+
diff --git a/recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0002-interconnect-qcom-Add-SM6115-interconnect-provider-d.patch b/recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0002-interconnect-qcom-Add-SM6115-interconnect-provider-d.patch
new file mode 100644
index 0000000..ad75aa3
--- /dev/null
+++ b/recipes-kernel/linux/linux-yocto/qrb4210-drivers/icc/0002-interconnect-qcom-Add-SM6115-interconnect-provider-d.patch
@@ -0,0 +1,1495 @@
+From 2eab57b131bd9ef22377e09de43beb45a650a752 Mon Sep 17 00:00:00 2001
+From: Konrad Dybcio <konrad.dybcio@linaro.org>
+Date: Wed, 29 Nov 2023 15:41:02 +0100
+Subject: [PATCH 2/2] interconnect: qcom: Add SM6115 interconnect provider
+ driver
+
+Add a driver for managing NoC providers on SM6115.
+
+Signed-off-by: Konrad Dybcio <konrad.dybcio@linaro.org>
+Link: https://lore.kernel.org/r/20231125-topic-6115icc-v3-2-bd8907b8cfd7@linaro.org
+Signed-off-by: Georgi Djakov <djakov@kernel.org>
+Upstream-Status: Backport [https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git 2eab57b131bd9ef22377e09de43beb45a650a752]
+---
+ drivers/interconnect/qcom/Kconfig | 9 +
+ drivers/interconnect/qcom/Makefile | 2 +
+ drivers/interconnect/qcom/sm6115.c | 1427 ++++++++++++++++++++++++++++
+ 3 files changed, 1438 insertions(+)
+ create mode 100644 drivers/interconnect/qcom/sm6115.c
+
+diff --git a/drivers/interconnect/qcom/Kconfig b/drivers/interconnect/qcom/Kconfig
+index 62b516d38d03..d2a54c5ecd06 100644
+--- a/drivers/interconnect/qcom/Kconfig
++++ b/drivers/interconnect/qcom/Kconfig
+@@ -182,6 +182,15 @@ config INTERCONNECT_QCOM_SDX65
+ This is a driver for the Qualcomm Network-on-Chip on sdx65-based
+ platforms.
+
++config INTERCONNECT_QCOM_SM6115
++ tristate "Qualcomm SM6115 interconnect driver"
++ depends on INTERCONNECT_QCOM
++ depends on QCOM_SMD_RPM
++ select INTERCONNECT_QCOM_SMD_RPM
++ help
++ This is a driver for the Qualcomm Network-on-Chip on sm6115-based
++ platforms.
++
+ config INTERCONNECT_QCOM_SM6350
+ tristate "Qualcomm SM6350 interconnect driver"
+ depends on INTERCONNECT_QCOM_RPMH_POSSIBLE
+diff --git a/drivers/interconnect/qcom/Makefile b/drivers/interconnect/qcom/Makefile
+index c5320e293960..7564042a30dc 100644
+--- a/drivers/interconnect/qcom/Makefile
++++ b/drivers/interconnect/qcom/Makefile
+@@ -24,6 +24,7 @@ qnoc-sdm845-objs := sdm845.o
+ qnoc-sdm845-objs := sdm845.o
+ qnoc-sdx55-objs := sdx55.o
+ qnoc-sdx65-objs := sdx65.o
++qnoc-sm6115-objs := sm6115.o
+ qnoc-sm6350-objs := sm6350.o
+ qnoc-sm8150-objs := sm8150.o
+ qnoc-sm8250-objs := sm8250.o
+@@ -53,6 +54,7 @@ obj-$(CONFIG_INTERCONNECT_QCOM_SDM845) += qnoc-sdm845.o
+ obj-$(CONFIG_INTERCONNECT_QCOM_SDM845) += qnoc-sdm845.o
+ obj-$(CONFIG_INTERCONNECT_QCOM_SDX55) += qnoc-sdx55.o
+ obj-$(CONFIG_INTERCONNECT_QCOM_SDX65) += qnoc-sdx65.o
++obj-$(CONFIG_INTERCONNECT_QCOM_SM6115) += qnoc-sm6115.o
+ obj-$(CONFIG_INTERCONNECT_QCOM_SM6350) += qnoc-sm6350.o
+ obj-$(CONFIG_INTERCONNECT_QCOM_SM8150) += qnoc-sm8150.o
+ obj-$(CONFIG_INTERCONNECT_QCOM_SM8250) += qnoc-sm8250.o
+diff --git a/drivers/interconnect/qcom/sm6115.c b/drivers/interconnect/qcom/sm6115.c
+new file mode 100644
+index 000000000000..c49a83c87739
+--- /dev/null
++++ b/drivers/interconnect/qcom/sm6115.c
+@@ -0,0 +1,1427 @@
++// SPDX-License-Identifier: GPL-2.0-only
++/*
++ * Copyright (c) 2021, The Linux Foundation. All rights reserved.
++ * Copyright (c) 2022, Qualcomm Innovation Center, Inc. All rights reserved.
++ * Copyright (c) 2023, Linaro Limited
++ */
++
++#include <dt-bindings/interconnect/qcom,sm6115.h>
++#include <linux/clk.h>
++#include <linux/device.h>
++#include <linux/interconnect-provider.h>
++#include <linux/io.h>
++#include <linux/module.h>
++#include <linux/of_device.h>
++#include <linux/of_platform.h>
++#include <linux/platform_device.h>
++#include <linux/regmap.h>
++#include <linux/slab.h>
++
++#include "icc-rpm.h"
++
++static const char * const snoc_intf_clocks[] = {
++ "cpu_axi",
++ "ufs_axi",
++ "usb_axi",
++ "ipa", /* Required by qxm_ipa */
++};
++
++static const char * const cnoc_intf_clocks[] = {
++ "usb_axi",
++};
++
++enum {
++ SM6115_MASTER_AMPSS_M0,
++ SM6115_MASTER_ANOC_SNOC,
++ SM6115_MASTER_BIMC_SNOC,
++ SM6115_MASTER_CAMNOC_HF,
++ SM6115_MASTER_CAMNOC_SF,
++ SM6115_MASTER_CRYPTO_CORE0,
++ SM6115_MASTER_GRAPHICS_3D,
++ SM6115_MASTER_IPA,
++ SM6115_MASTER_MDP_PORT0,
++ SM6115_MASTER_PIMEM,
++ SM6115_MASTER_QDSS_BAM,
++ SM6115_MASTER_QDSS_DAP,
++ SM6115_MASTER_QDSS_ETR,
++ SM6115_MASTER_QPIC,
++ SM6115_MASTER_QUP_0,
++ SM6115_MASTER_QUP_CORE_0,
++ SM6115_MASTER_SDCC_1,
++ SM6115_MASTER_SDCC_2,
++ SM6115_MASTER_SNOC_BIMC_NRT,
++ SM6115_MASTER_SNOC_BIMC_RT,
++ SM6115_MASTER_SNOC_BIMC,
++ SM6115_MASTER_SNOC_CFG,
++ SM6115_MASTER_SNOC_CNOC,
++ SM6115_MASTER_TCU_0,
++ SM6115_MASTER_TIC,
++ SM6115_MASTER_USB3,
++ SM6115_MASTER_VIDEO_P0,
++ SM6115_MASTER_VIDEO_PROC,
++
++ SM6115_SLAVE_AHB2PHY_USB,
++ SM6115_SLAVE_ANOC_SNOC,
++ SM6115_SLAVE_APPSS,
++ SM6115_SLAVE_APSS_THROTTLE_CFG,
++ SM6115_SLAVE_BIMC_CFG,
++ SM6115_SLAVE_BIMC_SNOC,
++ SM6115_SLAVE_BOOT_ROM,
++ SM6115_SLAVE_CAMERA_CFG,
++ SM6115_SLAVE_CAMERA_NRT_THROTTLE_CFG,
++ SM6115_SLAVE_CAMERA_RT_THROTTLE_CFG,
++ SM6115_SLAVE_CLK_CTL,
++ SM6115_SLAVE_CNOC_MSS,
++ SM6115_SLAVE_CRYPTO_0_CFG,
++ SM6115_SLAVE_DCC_CFG,
++ SM6115_SLAVE_DDR_PHY_CFG,
++ SM6115_SLAVE_DDR_SS_CFG,
++ SM6115_SLAVE_DISPLAY_CFG,
++ SM6115_SLAVE_DISPLAY_THROTTLE_CFG,
++ SM6115_SLAVE_EBI_CH0,
++ SM6115_SLAVE_GPU_CFG,
++ SM6115_SLAVE_GPU_THROTTLE_CFG,
++ SM6115_SLAVE_HWKM_CORE,
++ SM6115_SLAVE_IMEM_CFG,
++ SM6115_SLAVE_IPA_CFG,
++ SM6115_SLAVE_LPASS,
++ SM6115_SLAVE_MAPSS,
++ SM6115_SLAVE_MDSP_MPU_CFG,
++ SM6115_SLAVE_MESSAGE_RAM,
++ SM6115_SLAVE_OCIMEM,
++ SM6115_SLAVE_PDM,
++ SM6115_SLAVE_PIMEM_CFG,
++ SM6115_SLAVE_PIMEM,
++ SM6115_SLAVE_PKA_CORE,
++ SM6115_SLAVE_PMIC_ARB,
++ SM6115_SLAVE_QDSS_CFG,
++ SM6115_SLAVE_QDSS_STM,
++ SM6115_SLAVE_QM_CFG,
++ SM6115_SLAVE_QM_MPU_CFG,
++ SM6115_SLAVE_QPIC,
++ SM6115_SLAVE_QUP_0,
++ SM6115_SLAVE_QUP_CORE_0,
++ SM6115_SLAVE_RBCPR_CX_CFG,
++ SM6115_SLAVE_RBCPR_MX_CFG,
++ SM6115_SLAVE_RPM,
++ SM6115_SLAVE_SDCC_1,
++ SM6115_SLAVE_SDCC_2,
++ SM6115_SLAVE_SECURITY,
++ SM6115_SLAVE_SERVICE_CNOC,
++ SM6115_SLAVE_SERVICE_SNOC,
++ SM6115_SLAVE_SNOC_BIMC_NRT,
++ SM6115_SLAVE_SNOC_BIMC_RT,
++ SM6115_SLAVE_SNOC_BIMC,
++ SM6115_SLAVE_SNOC_CFG,
++ SM6115_SLAVE_SNOC_CNOC,
++ SM6115_SLAVE_TCSR,
++ SM6115_SLAVE_TCU,
++ SM6115_SLAVE_TLMM,
++ SM6115_SLAVE_USB3,
++ SM6115_SLAVE_VENUS_CFG,
++ SM6115_SLAVE_VENUS_THROTTLE_CFG,
++ SM6115_SLAVE_VSENSE_CTRL_CFG,
++};
++
++static const u16 slv_ebi_slv_bimc_snoc_links[] = {
++ SM6115_SLAVE_EBI_CH0,
++ SM6115_SLAVE_BIMC_SNOC,
++};
++
++static struct qcom_icc_node apps_proc = {
++ .name = "apps_proc",
++ .id = SM6115_MASTER_AMPSS_M0,
++ .channels = 1,
++ .buswidth = 16,
++ .qos.qos_port = 0,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.prio_level = 0,
++ .qos.areq_prio = 0,
++ .mas_rpm_id = 0,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(slv_ebi_slv_bimc_snoc_links),
++ .links = slv_ebi_slv_bimc_snoc_links,
++};
++
++static const u16 link_slv_ebi[] = {
++ SM6115_SLAVE_EBI_CH0,
++};
++
++static struct qcom_icc_node mas_snoc_bimc_rt = {
++ .name = "mas_snoc_bimc_rt",
++ .id = SM6115_MASTER_SNOC_BIMC_RT,
++ .channels = 1,
++ .buswidth = 16,
++ .qos.qos_port = 2,
++ .qos.qos_mode = NOC_QOS_MODE_BYPASS,
++ .qos.areq_prio = 0,
++ .qos.prio_level = 0,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_ebi),
++ .links = link_slv_ebi,
++};
++
++static struct qcom_icc_node mas_snoc_bimc_nrt = {
++ .name = "mas_snoc_bimc_nrt",
++ .id = SM6115_MASTER_SNOC_BIMC_NRT,
++ .channels = 1,
++ .buswidth = 16,
++ .qos.qos_port = 3,
++ .qos.qos_mode = NOC_QOS_MODE_BYPASS,
++ .qos.areq_prio = 0,
++ .qos.prio_level = 0,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_ebi),
++ .links = link_slv_ebi,
++};
++
++static struct qcom_icc_node mas_snoc_bimc = {
++ .name = "mas_snoc_bimc",
++ .id = SM6115_MASTER_SNOC_BIMC,
++ .channels = 1,
++ .buswidth = 16,
++ .qos.qos_port = 6,
++ .qos.qos_mode = NOC_QOS_MODE_BYPASS,
++ .qos.areq_prio = 0,
++ .qos.prio_level = 0,
++ .mas_rpm_id = 3,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_ebi),
++ .links = link_slv_ebi,
++};
++
++static struct qcom_icc_node qnm_gpu = {
++ .name = "qnm_gpu",
++ .id = SM6115_MASTER_GRAPHICS_3D,
++ .channels = 1,
++ .buswidth = 32,
++ .qos.qos_port = 1,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.prio_level = 0,
++ .qos.areq_prio = 0,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(slv_ebi_slv_bimc_snoc_links),
++ .links = slv_ebi_slv_bimc_snoc_links,
++};
++
++static struct qcom_icc_node tcu_0 = {
++ .name = "tcu_0",
++ .id = SM6115_MASTER_TCU_0,
++ .channels = 1,
++ .buswidth = 8,
++ .qos.qos_port = 4,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.prio_level = 6,
++ .qos.areq_prio = 6,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(slv_ebi_slv_bimc_snoc_links),
++ .links = slv_ebi_slv_bimc_snoc_links,
++};
++
++static const u16 qup_core_0_links[] = {
++ SM6115_SLAVE_QUP_CORE_0,
++};
++
++static struct qcom_icc_node qup0_core_master = {
++ .name = "qup0_core_master",
++ .id = SM6115_MASTER_QUP_CORE_0,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = 170,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(qup_core_0_links),
++ .links = qup_core_0_links,
++};
++
++static const u16 link_slv_anoc_snoc[] = {
++ SM6115_SLAVE_ANOC_SNOC,
++};
++
++static struct qcom_icc_node crypto_c0 = {
++ .name = "crypto_c0",
++ .id = SM6115_MASTER_CRYPTO_CORE0,
++ .channels = 1,
++ .buswidth = 8,
++ .qos.qos_port = 43,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 2,
++ .mas_rpm_id = 23,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
++ .links = link_slv_anoc_snoc,
++};
++
++static const u16 mas_snoc_cnoc_links[] = {
++ SM6115_SLAVE_AHB2PHY_USB,
++ SM6115_SLAVE_APSS_THROTTLE_CFG,
++ SM6115_SLAVE_BIMC_CFG,
++ SM6115_SLAVE_BOOT_ROM,
++ SM6115_SLAVE_CAMERA_CFG,
++ SM6115_SLAVE_CAMERA_NRT_THROTTLE_CFG,
++ SM6115_SLAVE_CAMERA_RT_THROTTLE_CFG,
++ SM6115_SLAVE_CLK_CTL,
++ SM6115_SLAVE_CNOC_MSS,
++ SM6115_SLAVE_CRYPTO_0_CFG,
++ SM6115_SLAVE_DCC_CFG,
++ SM6115_SLAVE_DDR_PHY_CFG,
++ SM6115_SLAVE_DDR_SS_CFG,
++ SM6115_SLAVE_DISPLAY_CFG,
++ SM6115_SLAVE_DISPLAY_THROTTLE_CFG,
++ SM6115_SLAVE_GPU_CFG,
++ SM6115_SLAVE_GPU_THROTTLE_CFG,
++ SM6115_SLAVE_HWKM_CORE,
++ SM6115_SLAVE_IMEM_CFG,
++ SM6115_SLAVE_IPA_CFG,
++ SM6115_SLAVE_LPASS,
++ SM6115_SLAVE_MAPSS,
++ SM6115_SLAVE_MDSP_MPU_CFG,
++ SM6115_SLAVE_MESSAGE_RAM,
++ SM6115_SLAVE_PDM,
++ SM6115_SLAVE_PIMEM_CFG,
++ SM6115_SLAVE_PKA_CORE,
++ SM6115_SLAVE_PMIC_ARB,
++ SM6115_SLAVE_QDSS_CFG,
++ SM6115_SLAVE_QM_CFG,
++ SM6115_SLAVE_QM_MPU_CFG,
++ SM6115_SLAVE_QPIC,
++ SM6115_SLAVE_QUP_0,
++ SM6115_SLAVE_RBCPR_CX_CFG,
++ SM6115_SLAVE_RBCPR_MX_CFG,
++ SM6115_SLAVE_RPM,
++ SM6115_SLAVE_SDCC_1,
++ SM6115_SLAVE_SDCC_2,
++ SM6115_SLAVE_SECURITY,
++ SM6115_SLAVE_SERVICE_CNOC,
++ SM6115_SLAVE_SNOC_CFG,
++ SM6115_SLAVE_TCSR,
++ SM6115_SLAVE_TLMM,
++ SM6115_SLAVE_USB3,
++ SM6115_SLAVE_VENUS_CFG,
++ SM6115_SLAVE_VENUS_THROTTLE_CFG,
++ SM6115_SLAVE_VSENSE_CTRL_CFG,
++};
++
++static struct qcom_icc_node mas_snoc_cnoc = {
++ .name = "mas_snoc_cnoc",
++ .id = SM6115_MASTER_SNOC_CNOC,
++ .channels = 1,
++ .buswidth = 8,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(mas_snoc_cnoc_links),
++ .links = mas_snoc_cnoc_links,
++};
++
++static struct qcom_icc_node xm_dap = {
++ .name = "xm_dap",
++ .id = SM6115_MASTER_QDSS_DAP,
++ .channels = 1,
++ .buswidth = 8,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(mas_snoc_cnoc_links),
++ .links = mas_snoc_cnoc_links,
++};
++
++static const u16 link_slv_snoc_bimc_nrt[] = {
++ SM6115_SLAVE_SNOC_BIMC_NRT,
++};
++
++static struct qcom_icc_node qnm_camera_nrt = {
++ .name = "qnm_camera_nrt",
++ .id = SM6115_MASTER_CAMNOC_SF,
++ .channels = 1,
++ .buswidth = 32,
++ .qos.qos_port = 25,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 3,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_snoc_bimc_nrt),
++ .links = link_slv_snoc_bimc_nrt,
++};
++
++static struct qcom_icc_node qxm_venus0 = {
++ .name = "qxm_venus0",
++ .id = SM6115_MASTER_VIDEO_P0,
++ .channels = 1,
++ .buswidth = 16,
++ .qos.qos_port = 30,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 3,
++ .qos.urg_fwd_en = true,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_snoc_bimc_nrt),
++ .links = link_slv_snoc_bimc_nrt,
++};
++
++static struct qcom_icc_node qxm_venus_cpu = {
++ .name = "qxm_venus_cpu",
++ .id = SM6115_MASTER_VIDEO_PROC,
++ .channels = 1,
++ .buswidth = 8,
++ .qos.qos_port = 34,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_snoc_bimc_nrt),
++ .links = link_slv_snoc_bimc_nrt,
++};
++
++static const u16 link_slv_snoc_bimc_rt[] = {
++ SM6115_SLAVE_SNOC_BIMC_RT,
++};
++
++static struct qcom_icc_node qnm_camera_rt = {
++ .name = "qnm_camera_rt",
++ .id = SM6115_MASTER_CAMNOC_HF,
++ .channels = 1,
++ .buswidth = 32,
++ .qos.qos_port = 31,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 3,
++ .qos.urg_fwd_en = true,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_snoc_bimc_rt),
++ .links = link_slv_snoc_bimc_rt,
++};
++
++static struct qcom_icc_node qxm_mdp0 = {
++ .name = "qxm_mdp0",
++ .id = SM6115_MASTER_MDP_PORT0,
++ .channels = 1,
++ .buswidth = 16,
++ .qos.qos_port = 26,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 3,
++ .qos.urg_fwd_en = true,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_snoc_bimc_rt),
++ .links = link_slv_snoc_bimc_rt,
++};
++
++static const u16 slv_service_snoc_links[] = {
++ SM6115_SLAVE_SERVICE_SNOC,
++};
++
++static struct qcom_icc_node qhm_snoc_cfg = {
++ .name = "qhm_snoc_cfg",
++ .id = SM6115_MASTER_SNOC_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(slv_service_snoc_links),
++ .links = slv_service_snoc_links,
++};
++
++static const u16 mas_tic_links[] = {
++ SM6115_SLAVE_APPSS,
++ SM6115_SLAVE_OCIMEM,
++ SM6115_SLAVE_PIMEM,
++ SM6115_SLAVE_QDSS_STM,
++ SM6115_SLAVE_TCU,
++ SM6115_SLAVE_SNOC_BIMC,
++ SM6115_SLAVE_SNOC_CNOC,
++};
++
++static struct qcom_icc_node qhm_tic = {
++ .name = "qhm_tic",
++ .id = SM6115_MASTER_TIC,
++ .channels = 1,
++ .buswidth = 4,
++ .qos.qos_port = 29,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 2,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(mas_tic_links),
++ .links = mas_tic_links,
++};
++
++static struct qcom_icc_node mas_anoc_snoc = {
++ .name = "mas_anoc_snoc",
++ .id = SM6115_MASTER_ANOC_SNOC,
++ .channels = 1,
++ .buswidth = 16,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(mas_tic_links),
++ .links = mas_tic_links,
++};
++
++static const u16 mas_bimc_snoc_links[] = {
++ SM6115_SLAVE_APPSS,
++ SM6115_SLAVE_SNOC_CNOC,
++ SM6115_SLAVE_OCIMEM,
++ SM6115_SLAVE_PIMEM,
++ SM6115_SLAVE_QDSS_STM,
++ SM6115_SLAVE_TCU,
++};
++
++static struct qcom_icc_node mas_bimc_snoc = {
++ .name = "mas_bimc_snoc",
++ .id = SM6115_MASTER_BIMC_SNOC,
++ .channels = 1,
++ .buswidth = 8,
++ .mas_rpm_id = 21,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(mas_bimc_snoc_links),
++ .links = mas_bimc_snoc_links,
++};
++
++static const u16 mas_pimem_links[] = {
++ SM6115_SLAVE_OCIMEM,
++ SM6115_SLAVE_SNOC_BIMC,
++};
++
++static struct qcom_icc_node qxm_pimem = {
++ .name = "qxm_pimem",
++ .id = SM6115_MASTER_PIMEM,
++ .channels = 1,
++ .buswidth = 8,
++ .qos.qos_port = 41,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 2,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(mas_pimem_links),
++ .links = mas_pimem_links,
++};
++
++static struct qcom_icc_node qhm_qdss_bam = {
++ .name = "qhm_qdss_bam",
++ .id = SM6115_MASTER_QDSS_BAM,
++ .channels = 1,
++ .buswidth = 4,
++ .qos.qos_port = 23,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 2,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
++ .links = link_slv_anoc_snoc,
++};
++
++static struct qcom_icc_node qhm_qpic = {
++ .name = "qhm_qpic",
++ .id = SM6115_MASTER_QPIC,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
++ .links = link_slv_anoc_snoc,
++};
++
++static struct qcom_icc_node qhm_qup0 = {
++ .name = "qhm_qup0",
++ .id = SM6115_MASTER_QUP_0,
++ .channels = 1,
++ .buswidth = 4,
++ .qos.qos_port = 21,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 2,
++ .mas_rpm_id = 166,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
++ .links = link_slv_anoc_snoc,
++};
++
++static struct qcom_icc_node qxm_ipa = {
++ .name = "qxm_ipa",
++ .id = SM6115_MASTER_IPA,
++ .channels = 1,
++ .buswidth = 8,
++ .qos.qos_port = 24,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 2,
++ .mas_rpm_id = 59,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
++ .links = link_slv_anoc_snoc,
++};
++
++static struct qcom_icc_node xm_qdss_etr = {
++ .name = "xm_qdss_etr",
++ .id = SM6115_MASTER_QDSS_ETR,
++ .channels = 1,
++ .buswidth = 8,
++ .qos.qos_port = 33,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 2,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
++ .links = link_slv_anoc_snoc,
++};
++
++static struct qcom_icc_node xm_sdc1 = {
++ .name = "xm_sdc1",
++ .id = SM6115_MASTER_SDCC_1,
++ .channels = 1,
++ .buswidth = 8,
++ .qos.qos_port = 38,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 2,
++ .mas_rpm_id = 33,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
++ .links = link_slv_anoc_snoc,
++};
++
++static struct qcom_icc_node xm_sdc2 = {
++ .name = "xm_sdc2",
++ .id = SM6115_MASTER_SDCC_2,
++ .channels = 1,
++ .buswidth = 8,
++ .qos.qos_port = 44,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 2,
++ .mas_rpm_id = 35,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
++ .links = link_slv_anoc_snoc,
++};
++
++static struct qcom_icc_node xm_usb3_0 = {
++ .name = "xm_usb3_0",
++ .id = SM6115_MASTER_USB3,
++ .channels = 1,
++ .buswidth = 8,
++ .qos.qos_port = 45,
++ .qos.qos_mode = NOC_QOS_MODE_FIXED,
++ .qos.areq_prio = 2,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
++ .links = link_slv_anoc_snoc,
++};
++
++static struct qcom_icc_node ebi = {
++ .name = "ebi",
++ .id = SM6115_SLAVE_EBI_CH0,
++ .channels = 2,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = 0,
++};
++
++static const u16 slv_bimc_snoc_links[] = {
++ SM6115_MASTER_BIMC_SNOC,
++};
++
++static struct qcom_icc_node slv_bimc_snoc = {
++ .name = "slv_bimc_snoc",
++ .id = SM6115_SLAVE_BIMC_SNOC,
++ .channels = 1,
++ .buswidth = 16,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = 2,
++ .num_links = ARRAY_SIZE(slv_bimc_snoc_links),
++ .links = slv_bimc_snoc_links,
++};
++
++static struct qcom_icc_node qup0_core_slave = {
++ .name = "qup0_core_slave",
++ .id = SM6115_SLAVE_QUP_CORE_0,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_ahb2phy_usb = {
++ .name = "qhs_ahb2phy_usb",
++ .id = SM6115_SLAVE_AHB2PHY_USB,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_apss_throttle_cfg = {
++ .name = "qhs_apss_throttle_cfg",
++ .id = SM6115_SLAVE_APSS_THROTTLE_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_bimc_cfg = {
++ .name = "qhs_bimc_cfg",
++ .id = SM6115_SLAVE_BIMC_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_boot_rom = {
++ .name = "qhs_boot_rom",
++ .id = SM6115_SLAVE_BOOT_ROM,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_camera_nrt_throttle_cfg = {
++ .name = "qhs_camera_nrt_throttle_cfg",
++ .id = SM6115_SLAVE_CAMERA_NRT_THROTTLE_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_camera_rt_throttle_cfg = {
++ .name = "qhs_camera_rt_throttle_cfg",
++ .id = SM6115_SLAVE_CAMERA_RT_THROTTLE_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_camera_ss_cfg = {
++ .name = "qhs_camera_ss_cfg",
++ .id = SM6115_SLAVE_CAMERA_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_clk_ctl = {
++ .name = "qhs_clk_ctl",
++ .id = SM6115_SLAVE_CLK_CTL,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_cpr_cx = {
++ .name = "qhs_cpr_cx",
++ .id = SM6115_SLAVE_RBCPR_CX_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_cpr_mx = {
++ .name = "qhs_cpr_mx",
++ .id = SM6115_SLAVE_RBCPR_MX_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_crypto0_cfg = {
++ .name = "qhs_crypto0_cfg",
++ .id = SM6115_SLAVE_CRYPTO_0_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_dcc_cfg = {
++ .name = "qhs_dcc_cfg",
++ .id = SM6115_SLAVE_DCC_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_ddr_phy_cfg = {
++ .name = "qhs_ddr_phy_cfg",
++ .id = SM6115_SLAVE_DDR_PHY_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_ddr_ss_cfg = {
++ .name = "qhs_ddr_ss_cfg",
++ .id = SM6115_SLAVE_DDR_SS_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_disp_ss_cfg = {
++ .name = "qhs_disp_ss_cfg",
++ .id = SM6115_SLAVE_DISPLAY_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_display_throttle_cfg = {
++ .name = "qhs_display_throttle_cfg",
++ .id = SM6115_SLAVE_DISPLAY_THROTTLE_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_gpu_cfg = {
++ .name = "qhs_gpu_cfg",
++ .id = SM6115_SLAVE_GPU_CFG,
++ .channels = 1,
++ .buswidth = 8,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_gpu_throttle_cfg = {
++ .name = "qhs_gpu_throttle_cfg",
++ .id = SM6115_SLAVE_GPU_THROTTLE_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_hwkm = {
++ .name = "qhs_hwkm",
++ .id = SM6115_SLAVE_HWKM_CORE,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_imem_cfg = {
++ .name = "qhs_imem_cfg",
++ .id = SM6115_SLAVE_IMEM_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_ipa_cfg = {
++ .name = "qhs_ipa_cfg",
++ .id = SM6115_SLAVE_IPA_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_lpass = {
++ .name = "qhs_lpass",
++ .id = SM6115_SLAVE_LPASS,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_mapss = {
++ .name = "qhs_mapss",
++ .id = SM6115_SLAVE_MAPSS,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_mdsp_mpu_cfg = {
++ .name = "qhs_mdsp_mpu_cfg",
++ .id = SM6115_SLAVE_MDSP_MPU_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_mesg_ram = {
++ .name = "qhs_mesg_ram",
++ .id = SM6115_SLAVE_MESSAGE_RAM,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_mss = {
++ .name = "qhs_mss",
++ .id = SM6115_SLAVE_CNOC_MSS,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_pdm = {
++ .name = "qhs_pdm",
++ .id = SM6115_SLAVE_PDM,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_pimem_cfg = {
++ .name = "qhs_pimem_cfg",
++ .id = SM6115_SLAVE_PIMEM_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_pka_wrapper = {
++ .name = "qhs_pka_wrapper",
++ .id = SM6115_SLAVE_PKA_CORE,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_pmic_arb = {
++ .name = "qhs_pmic_arb",
++ .id = SM6115_SLAVE_PMIC_ARB,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_qdss_cfg = {
++ .name = "qhs_qdss_cfg",
++ .id = SM6115_SLAVE_QDSS_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_qm_cfg = {
++ .name = "qhs_qm_cfg",
++ .id = SM6115_SLAVE_QM_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_qm_mpu_cfg = {
++ .name = "qhs_qm_mpu_cfg",
++ .id = SM6115_SLAVE_QM_MPU_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_qpic = {
++ .name = "qhs_qpic",
++ .id = SM6115_SLAVE_QPIC,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_qup0 = {
++ .name = "qhs_qup0",
++ .id = SM6115_SLAVE_QUP_0,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_rpm = {
++ .name = "qhs_rpm",
++ .id = SM6115_SLAVE_RPM,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_sdc1 = {
++ .name = "qhs_sdc1",
++ .id = SM6115_SLAVE_SDCC_1,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_sdc2 = {
++ .name = "qhs_sdc2",
++ .id = SM6115_SLAVE_SDCC_2,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_security = {
++ .name = "qhs_security",
++ .id = SM6115_SLAVE_SECURITY,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static const u16 slv_snoc_cfg_links[] = {
++ SM6115_MASTER_SNOC_CFG,
++};
++
++static struct qcom_icc_node qhs_snoc_cfg = {
++ .name = "qhs_snoc_cfg",
++ .id = SM6115_SLAVE_SNOC_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(slv_snoc_cfg_links),
++ .links = slv_snoc_cfg_links,
++};
++
++static struct qcom_icc_node qhs_tcsr = {
++ .name = "qhs_tcsr",
++ .id = SM6115_SLAVE_TCSR,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_tlmm = {
++ .name = "qhs_tlmm",
++ .id = SM6115_SLAVE_TLMM,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_usb3 = {
++ .name = "qhs_usb3",
++ .id = SM6115_SLAVE_USB3,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_venus_cfg = {
++ .name = "qhs_venus_cfg",
++ .id = SM6115_SLAVE_VENUS_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_venus_throttle_cfg = {
++ .name = "qhs_venus_throttle_cfg",
++ .id = SM6115_SLAVE_VENUS_THROTTLE_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node qhs_vsense_ctrl_cfg = {
++ .name = "qhs_vsense_ctrl_cfg",
++ .id = SM6115_SLAVE_VSENSE_CTRL_CFG,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node srvc_cnoc = {
++ .name = "srvc_cnoc",
++ .id = SM6115_SLAVE_SERVICE_CNOC,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static const u16 slv_snoc_bimc_nrt_links[] = {
++ SM6115_MASTER_SNOC_BIMC_NRT,
++};
++
++static struct qcom_icc_node slv_snoc_bimc_nrt = {
++ .name = "slv_snoc_bimc_nrt",
++ .id = SM6115_SLAVE_SNOC_BIMC_NRT,
++ .channels = 1,
++ .buswidth = 16,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(slv_snoc_bimc_nrt_links),
++ .links = slv_snoc_bimc_nrt_links,
++};
++
++static const u16 slv_snoc_bimc_rt_links[] = {
++ SM6115_MASTER_SNOC_BIMC_RT,
++};
++
++static struct qcom_icc_node slv_snoc_bimc_rt = {
++ .name = "slv_snoc_bimc_rt",
++ .id = SM6115_SLAVE_SNOC_BIMC_RT,
++ .channels = 1,
++ .buswidth = 16,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(slv_snoc_bimc_rt_links),
++ .links = slv_snoc_bimc_rt_links,
++};
++
++static struct qcom_icc_node qhs_apss = {
++ .name = "qhs_apss",
++ .id = SM6115_SLAVE_APPSS,
++ .channels = 1,
++ .buswidth = 8,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static const u16 slv_snoc_cnoc_links[] = {
++ SM6115_MASTER_SNOC_CNOC
++};
++
++static struct qcom_icc_node slv_snoc_cnoc = {
++ .name = "slv_snoc_cnoc",
++ .id = SM6115_SLAVE_SNOC_CNOC,
++ .channels = 1,
++ .buswidth = 8,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = 25,
++ .num_links = ARRAY_SIZE(slv_snoc_cnoc_links),
++ .links = slv_snoc_cnoc_links,
++};
++
++static struct qcom_icc_node qxs_imem = {
++ .name = "qxs_imem",
++ .id = SM6115_SLAVE_OCIMEM,
++ .channels = 1,
++ .buswidth = 8,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = 26,
++};
++
++static struct qcom_icc_node qxs_pimem = {
++ .name = "qxs_pimem",
++ .id = SM6115_SLAVE_PIMEM,
++ .channels = 1,
++ .buswidth = 8,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static const u16 slv_snoc_bimc_links[] = {
++ SM6115_MASTER_SNOC_BIMC,
++};
++
++static struct qcom_icc_node slv_snoc_bimc = {
++ .name = "slv_snoc_bimc",
++ .id = SM6115_SLAVE_SNOC_BIMC,
++ .channels = 1,
++ .buswidth = 16,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = 24,
++ .num_links = ARRAY_SIZE(slv_snoc_bimc_links),
++ .links = slv_snoc_bimc_links,
++};
++
++static struct qcom_icc_node srvc_snoc = {
++ .name = "srvc_snoc",
++ .id = SM6115_SLAVE_SERVICE_SNOC,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static struct qcom_icc_node xs_qdss_stm = {
++ .name = "xs_qdss_stm",
++ .id = SM6115_SLAVE_QDSS_STM,
++ .channels = 1,
++ .buswidth = 4,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = 30,
++};
++
++static struct qcom_icc_node xs_sys_tcu_cfg = {
++ .name = "xs_sys_tcu_cfg",
++ .id = SM6115_SLAVE_TCU,
++ .channels = 1,
++ .buswidth = 8,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++};
++
++static const u16 slv_anoc_snoc_links[] = {
++ SM6115_MASTER_ANOC_SNOC,
++};
++
++static struct qcom_icc_node slv_anoc_snoc = {
++ .name = "slv_anoc_snoc",
++ .id = SM6115_SLAVE_ANOC_SNOC,
++ .channels = 1,
++ .buswidth = 16,
++ .mas_rpm_id = -1,
++ .slv_rpm_id = -1,
++ .num_links = ARRAY_SIZE(slv_anoc_snoc_links),
++ .links = slv_anoc_snoc_links,
++};
++
++static struct qcom_icc_node *bimc_nodes[] = {
++ [MASTER_AMPSS_M0] = &apps_proc,
++ [MASTER_SNOC_BIMC_RT] = &mas_snoc_bimc_rt,
++ [MASTER_SNOC_BIMC_NRT] = &mas_snoc_bimc_nrt,
++ [SNOC_BIMC_MAS] = &mas_snoc_bimc,
++ [MASTER_GRAPHICS_3D] = &qnm_gpu,
++ [MASTER_TCU_0] = &tcu_0,
++ [SLAVE_EBI_CH0] = &ebi,
++ [BIMC_SNOC_SLV] = &slv_bimc_snoc,
++};
++
++static const struct regmap_config bimc_regmap_config = {
++ .reg_bits = 32,
++ .reg_stride = 4,
++ .val_bits = 32,
++ .max_register = 0x80000,
++ .fast_io = true,
++};
++
++static const struct qcom_icc_desc sm6115_bimc = {
++ .type = QCOM_ICC_BIMC,
++ .nodes = bimc_nodes,
++ .num_nodes = ARRAY_SIZE(bimc_nodes),
++ .regmap_cfg = &bimc_regmap_config,
++ .bus_clk_desc = &bimc_clk,
++ .keep_alive = true,
++ .qos_offset = 0x8000,
++ .ab_coeff = 153,
++};
++
++static struct qcom_icc_node *config_noc_nodes[] = {
++ [SNOC_CNOC_MAS] = &mas_snoc_cnoc,
++ [MASTER_QDSS_DAP] = &xm_dap,
++ [SLAVE_AHB2PHY_USB] = &qhs_ahb2phy_usb,
++ [SLAVE_APSS_THROTTLE_CFG] = &qhs_apss_throttle_cfg,
++ [SLAVE_BIMC_CFG] = &qhs_bimc_cfg,
++ [SLAVE_BOOT_ROM] = &qhs_boot_rom,
++ [SLAVE_CAMERA_NRT_THROTTLE_CFG] = &qhs_camera_nrt_throttle_cfg,
++ [SLAVE_CAMERA_RT_THROTTLE_CFG] = &qhs_camera_rt_throttle_cfg,
++ [SLAVE_CAMERA_CFG] = &qhs_camera_ss_cfg,
++ [SLAVE_CLK_CTL] = &qhs_clk_ctl,
++ [SLAVE_RBCPR_CX_CFG] = &qhs_cpr_cx,
++ [SLAVE_RBCPR_MX_CFG] = &qhs_cpr_mx,
++ [SLAVE_CRYPTO_0_CFG] = &qhs_crypto0_cfg,
++ [SLAVE_DCC_CFG] = &qhs_dcc_cfg,
++ [SLAVE_DDR_PHY_CFG] = &qhs_ddr_phy_cfg,
++ [SLAVE_DDR_SS_CFG] = &qhs_ddr_ss_cfg,
++ [SLAVE_DISPLAY_CFG] = &qhs_disp_ss_cfg,
++ [SLAVE_DISPLAY_THROTTLE_CFG] = &qhs_display_throttle_cfg,
++ [SLAVE_GPU_CFG] = &qhs_gpu_cfg,
++ [SLAVE_GPU_THROTTLE_CFG] = &qhs_gpu_throttle_cfg,
++ [SLAVE_HWKM_CORE] = &qhs_hwkm,
++ [SLAVE_IMEM_CFG] = &qhs_imem_cfg,
++ [SLAVE_IPA_CFG] = &qhs_ipa_cfg,
++ [SLAVE_LPASS] = &qhs_lpass,
++ [SLAVE_MAPSS] = &qhs_mapss,
++ [SLAVE_MDSP_MPU_CFG] = &qhs_mdsp_mpu_cfg,
++ [SLAVE_MESSAGE_RAM] = &qhs_mesg_ram,
++ [SLAVE_CNOC_MSS] = &qhs_mss,
++ [SLAVE_PDM] = &qhs_pdm,
++ [SLAVE_PIMEM_CFG] = &qhs_pimem_cfg,
++ [SLAVE_PKA_CORE] = &qhs_pka_wrapper,
++ [SLAVE_PMIC_ARB] = &qhs_pmic_arb,
++ [SLAVE_QDSS_CFG] = &qhs_qdss_cfg,
++ [SLAVE_QM_CFG] = &qhs_qm_cfg,
++ [SLAVE_QM_MPU_CFG] = &qhs_qm_mpu_cfg,
++ [SLAVE_QPIC] = &qhs_qpic,
++ [SLAVE_QUP_0] = &qhs_qup0,
++ [SLAVE_RPM] = &qhs_rpm,
++ [SLAVE_SDCC_1] = &qhs_sdc1,
++ [SLAVE_SDCC_2] = &qhs_sdc2,
++ [SLAVE_SECURITY] = &qhs_security,
++ [SLAVE_SNOC_CFG] = &qhs_snoc_cfg,
++ [SLAVE_TCSR] = &qhs_tcsr,
++ [SLAVE_TLMM] = &qhs_tlmm,
++ [SLAVE_USB3] = &qhs_usb3,
++ [SLAVE_VENUS_CFG] = &qhs_venus_cfg,
++ [SLAVE_VENUS_THROTTLE_CFG] = &qhs_venus_throttle_cfg,
++ [SLAVE_VSENSE_CTRL_CFG] = &qhs_vsense_ctrl_cfg,
++ [SLAVE_SERVICE_CNOC] = &srvc_cnoc,
++};
++
++static const struct regmap_config cnoc_regmap_config = {
++ .reg_bits = 32,
++ .reg_stride = 4,
++ .val_bits = 32,
++ .max_register = 0x6200,
++ .fast_io = true,
++};
++
++static const struct qcom_icc_desc sm6115_config_noc = {
++ .type = QCOM_ICC_QNOC,
++ .nodes = config_noc_nodes,
++ .num_nodes = ARRAY_SIZE(config_noc_nodes),
++ .regmap_cfg = &cnoc_regmap_config,
++ .intf_clocks = cnoc_intf_clocks,
++ .num_intf_clocks = ARRAY_SIZE(cnoc_intf_clocks),
++ .bus_clk_desc = &bus_1_clk,
++ .keep_alive = true,
++};
++
++static struct qcom_icc_node *sys_noc_nodes[] = {
++ [MASTER_CRYPTO_CORE0] = &crypto_c0,
++ [MASTER_SNOC_CFG] = &qhm_snoc_cfg,
++ [MASTER_TIC] = &qhm_tic,
++ [MASTER_ANOC_SNOC] = &mas_anoc_snoc,
++ [BIMC_SNOC_MAS] = &mas_bimc_snoc,
++ [MASTER_PIMEM] = &qxm_pimem,
++ [MASTER_QDSS_BAM] = &qhm_qdss_bam,
++ [MASTER_QPIC] = &qhm_qpic,
++ [MASTER_QUP_0] = &qhm_qup0,
++ [MASTER_IPA] = &qxm_ipa,
++ [MASTER_QDSS_ETR] = &xm_qdss_etr,
++ [MASTER_SDCC_1] = &xm_sdc1,
++ [MASTER_SDCC_2] = &xm_sdc2,
++ [MASTER_USB3] = &xm_usb3_0,
++ [SLAVE_APPSS] = &qhs_apss,
++ [SNOC_CNOC_SLV] = &slv_snoc_cnoc,
++ [SLAVE_OCIMEM] = &qxs_imem,
++ [SLAVE_PIMEM] = &qxs_pimem,
++ [SNOC_BIMC_SLV] = &slv_snoc_bimc,
++ [SLAVE_SERVICE_SNOC] = &srvc_snoc,
++ [SLAVE_QDSS_STM] = &xs_qdss_stm,
++ [SLAVE_TCU] = &xs_sys_tcu_cfg,
++ [SLAVE_ANOC_SNOC] = &slv_anoc_snoc,
++};
++
++static const struct regmap_config sys_noc_regmap_config = {
++ .reg_bits = 32,
++ .reg_stride = 4,
++ .val_bits = 32,
++ .max_register = 0x5f080,
++ .fast_io = true,
++};
++
++static const struct qcom_icc_desc sm6115_sys_noc = {
++ .type = QCOM_ICC_QNOC,
++ .nodes = sys_noc_nodes,
++ .num_nodes = ARRAY_SIZE(sys_noc_nodes),
++ .regmap_cfg = &sys_noc_regmap_config,
++ .intf_clocks = snoc_intf_clocks,
++ .num_intf_clocks = ARRAY_SIZE(snoc_intf_clocks),
++ .bus_clk_desc = &bus_2_clk,
++ .keep_alive = true,
++};
++
++static struct qcom_icc_node *clk_virt_nodes[] = {
++ [MASTER_QUP_CORE_0] = &qup0_core_master,
++ [SLAVE_QUP_CORE_0] = &qup0_core_slave,
++};
++
++static const struct qcom_icc_desc sm6115_clk_virt = {
++ .type = QCOM_ICC_QNOC,
++ .nodes = clk_virt_nodes,
++ .num_nodes = ARRAY_SIZE(clk_virt_nodes),
++ .regmap_cfg = &sys_noc_regmap_config,
++ .bus_clk_desc = &qup_clk,
++ .keep_alive = true,
++};
++
++static struct qcom_icc_node *mmnrt_virt_nodes[] = {
++ [MASTER_CAMNOC_SF] = &qnm_camera_nrt,
++ [MASTER_VIDEO_P0] = &qxm_venus0,
++ [MASTER_VIDEO_PROC] = &qxm_venus_cpu,
++ [SLAVE_SNOC_BIMC_NRT] = &slv_snoc_bimc_nrt,
++};
++
++static const struct qcom_icc_desc sm6115_mmnrt_virt = {
++ .type = QCOM_ICC_QNOC,
++ .nodes = mmnrt_virt_nodes,
++ .num_nodes = ARRAY_SIZE(mmnrt_virt_nodes),
++ .regmap_cfg = &sys_noc_regmap_config,
++ .bus_clk_desc = &mmaxi_0_clk,
++ .keep_alive = true,
++ .ab_coeff = 142,
++};
++
++static struct qcom_icc_node *mmrt_virt_nodes[] = {
++ [MASTER_CAMNOC_HF] = &qnm_camera_rt,
++ [MASTER_MDP_PORT0] = &qxm_mdp0,
++ [SLAVE_SNOC_BIMC_RT] = &slv_snoc_bimc_rt,
++};
++
++static const struct qcom_icc_desc sm6115_mmrt_virt = {
++ .type = QCOM_ICC_QNOC,
++ .nodes = mmrt_virt_nodes,
++ .num_nodes = ARRAY_SIZE(mmrt_virt_nodes),
++ .regmap_cfg = &sys_noc_regmap_config,
++ .bus_clk_desc = &mmaxi_1_clk,
++ .keep_alive = true,
++ .ab_coeff = 139,
++};
++
++static const struct of_device_id qnoc_of_match[] = {
++ { .compatible = "qcom,sm6115-bimc", .data = &sm6115_bimc },
++ { .compatible = "qcom,sm6115-clk-virt", .data = &sm6115_clk_virt },
++ { .compatible = "qcom,sm6115-cnoc", .data = &sm6115_config_noc },
++ { .compatible = "qcom,sm6115-mmrt-virt", .data = &sm6115_mmrt_virt },
++ { .compatible = "qcom,sm6115-mmnrt-virt", .data = &sm6115_mmnrt_virt },
++ { .compatible = "qcom,sm6115-snoc", .data = &sm6115_sys_noc },
++ { }
++};
++MODULE_DEVICE_TABLE(of, qnoc_of_match);
++
++static struct platform_driver qnoc_driver = {
++ .probe = qnoc_probe,
++ .remove = qnoc_remove,
++ .driver = {
++ .name = "qnoc-sm6115",
++ .of_match_table = qnoc_of_match,
++ .sync_state = icc_sync_state,
++ },
++};
++
++static int __init qnoc_driver_init(void)
++{
++ return platform_driver_register(&qnoc_driver);
++}
++core_initcall(qnoc_driver_init);
++
++static void __exit qnoc_driver_exit(void)
++{
++ platform_driver_unregister(&qnoc_driver);
++}
++module_exit(qnoc_driver_exit);
++
++MODULE_DESCRIPTION("SM6115 NoC driver");
++MODULE_LICENSE("GPL");
+--
+2.39.2
+