2019-01-16 18:11:00 +02:00
// SPDX-License-Identifier: GPL-2.0
/*
2020-02-28 12:11:40 +02:00
* Copyright ( c ) 2018 - 2020 , The Linux Foundation . All rights reserved .
2019-01-16 18:11:00 +02:00
*/
# include <linux/device.h>
# include <linux/interconnect.h>
# include <linux/interconnect-provider.h>
# include <linux/module.h>
# include <linux/of_device.h>
2020-02-28 12:11:40 +02:00
# include <dt-bindings/interconnect/qcom,sdm845.h>
2019-01-16 18:11:00 +02:00
2020-02-28 12:11:40 +02:00
# include "bcm-voter.h"
# include "icc-rpmh.h"
2020-03-03 19:02:52 +02:00
# include "sdm845.h"
2019-01-16 18:11:00 +02:00
2020-02-28 12:11:40 +02:00
DEFINE_QNODE ( qhm_a1noc_cfg , SDM845_MASTER_A1NOC_CFG , 1 , 4 , SDM845_SLAVE_SERVICE_A1NOC ) ;
DEFINE_QNODE ( qhm_qup1 , SDM845_MASTER_BLSP_1 , 1 , 4 , SDM845_SLAVE_A1NOC_SNOC ) ;
DEFINE_QNODE ( qhm_tsif , SDM845_MASTER_TSIF , 1 , 4 , SDM845_SLAVE_A1NOC_SNOC ) ;
DEFINE_QNODE ( xm_sdc2 , SDM845_MASTER_SDCC_2 , 1 , 8 , SDM845_SLAVE_A1NOC_SNOC ) ;
DEFINE_QNODE ( xm_sdc4 , SDM845_MASTER_SDCC_4 , 1 , 8 , SDM845_SLAVE_A1NOC_SNOC ) ;
DEFINE_QNODE ( xm_ufs_card , SDM845_MASTER_UFS_CARD , 1 , 8 , SDM845_SLAVE_A1NOC_SNOC ) ;
DEFINE_QNODE ( xm_ufs_mem , SDM845_MASTER_UFS_MEM , 1 , 8 , SDM845_SLAVE_A1NOC_SNOC ) ;
DEFINE_QNODE ( xm_pcie_0 , SDM845_MASTER_PCIE_0 , 1 , 8 , SDM845_SLAVE_ANOC_PCIE_A1NOC_SNOC ) ;
DEFINE_QNODE ( qhm_a2noc_cfg , SDM845_MASTER_A2NOC_CFG , 1 , 4 , SDM845_SLAVE_SERVICE_A2NOC ) ;
DEFINE_QNODE ( qhm_qdss_bam , SDM845_MASTER_QDSS_BAM , 1 , 4 , SDM845_SLAVE_A2NOC_SNOC ) ;
DEFINE_QNODE ( qhm_qup2 , SDM845_MASTER_BLSP_2 , 1 , 4 , SDM845_SLAVE_A2NOC_SNOC ) ;
DEFINE_QNODE ( qnm_cnoc , SDM845_MASTER_CNOC_A2NOC , 1 , 8 , SDM845_SLAVE_A2NOC_SNOC ) ;
DEFINE_QNODE ( qxm_crypto , SDM845_MASTER_CRYPTO , 1 , 8 , SDM845_SLAVE_A2NOC_SNOC ) ;
DEFINE_QNODE ( qxm_ipa , SDM845_MASTER_IPA , 1 , 8 , SDM845_SLAVE_A2NOC_SNOC ) ;
DEFINE_QNODE ( xm_pcie3_1 , SDM845_MASTER_PCIE_1 , 1 , 8 , SDM845_SLAVE_ANOC_PCIE_SNOC ) ;
DEFINE_QNODE ( xm_qdss_etr , SDM845_MASTER_QDSS_ETR , 1 , 8 , SDM845_SLAVE_A2NOC_SNOC ) ;
DEFINE_QNODE ( xm_usb3_0 , SDM845_MASTER_USB3_0 , 1 , 8 , SDM845_SLAVE_A2NOC_SNOC ) ;
DEFINE_QNODE ( xm_usb3_1 , SDM845_MASTER_USB3_1 , 1 , 8 , SDM845_SLAVE_A2NOC_SNOC ) ;
DEFINE_QNODE ( qxm_camnoc_hf0_uncomp , SDM845_MASTER_CAMNOC_HF0_UNCOMP , 1 , 32 , SDM845_SLAVE_CAMNOC_UNCOMP ) ;
DEFINE_QNODE ( qxm_camnoc_hf1_uncomp , SDM845_MASTER_CAMNOC_HF1_UNCOMP , 1 , 32 , SDM845_SLAVE_CAMNOC_UNCOMP ) ;
DEFINE_QNODE ( qxm_camnoc_sf_uncomp , SDM845_MASTER_CAMNOC_SF_UNCOMP , 1 , 32 , SDM845_SLAVE_CAMNOC_UNCOMP ) ;
DEFINE_QNODE ( qhm_spdm , SDM845_MASTER_SPDM , 1 , 4 , SDM845_SLAVE_CNOC_A2NOC ) ;
DEFINE_QNODE ( qhm_tic , SDM845_MASTER_TIC , 1 , 4 , SDM845_SLAVE_A1NOC_CFG , SDM845_SLAVE_A2NOC_CFG , SDM845_SLAVE_AOP , SDM845_SLAVE_AOSS , SDM845_SLAVE_CAMERA_CFG , SDM845_SLAVE_CLK_CTL , SDM845_SLAVE_CDSP_CFG , SDM845_SLAVE_RBCPR_CX_CFG , SDM845_SLAVE_CRYPTO_0_CFG , SDM845_SLAVE_DCC_CFG , SDM845_SLAVE_CNOC_DDRSS , SDM845_SLAVE_DISPLAY_CFG , SDM845_SLAVE_GLM , SDM845_SLAVE_GFX3D_CFG , SDM845_SLAVE_IMEM_CFG , SDM845_SLAVE_IPA_CFG , SDM845_SLAVE_CNOC_MNOC_CFG , SDM845_SLAVE_PCIE_0_CFG , SDM845_SLAVE_PCIE_1_CFG , SDM845_SLAVE_PDM , SDM845_SLAVE_SOUTH_PHY_CFG , SDM845_SLAVE_PIMEM_CFG , SDM845_SLAVE_PRNG , SDM845_SLAVE_QDSS_CFG , SDM845_SLAVE_BLSP_2 , SDM845_SLAVE_BLSP_1 , SDM845_SLAVE_SDCC_2 , SDM845_SLAVE_SDCC_4 , SDM845_SLAVE_SNOC_CFG , SDM845_SLAVE_SPDM_WRAPPER , SDM845_SLAVE_SPSS_CFG , SDM845_SLAVE_TCSR , SDM845_SLAVE_TLMM_NORTH , SDM845_SLAVE_TLMM_SOUTH , SDM845_SLAVE_TSIF , SDM845_SLAVE_UFS_CARD_CFG , SDM845_SLAVE_UFS_MEM_CFG , SDM845_SLAVE_USB3_0 , SDM845_SLAVE_USB3_1 , SDM845_SLAVE_VENUS_CFG , SDM845_SLAVE_VSENSE_CTRL_CFG , SDM845_SLAVE_CNOC_A2NOC , SDM845_SLAVE_SERVICE_CNOC ) ;
DEFINE_QNODE ( qnm_snoc , SDM845_MASTER_SNOC_CNOC , 1 , 8 , SDM845_SLAVE_A1NOC_CFG , SDM845_SLAVE_A2NOC_CFG , SDM845_SLAVE_AOP , SDM845_SLAVE_AOSS , SDM845_SLAVE_CAMERA_CFG , SDM845_SLAVE_CLK_CTL , SDM845_SLAVE_CDSP_CFG , SDM845_SLAVE_RBCPR_CX_CFG , SDM845_SLAVE_CRYPTO_0_CFG , SDM845_SLAVE_DCC_CFG , SDM845_SLAVE_CNOC_DDRSS , SDM845_SLAVE_DISPLAY_CFG , SDM845_SLAVE_GLM , SDM845_SLAVE_GFX3D_CFG , SDM845_SLAVE_IMEM_CFG , SDM845_SLAVE_IPA_CFG , SDM845_SLAVE_CNOC_MNOC_CFG , SDM845_SLAVE_PCIE_0_CFG , SDM845_SLAVE_PCIE_1_CFG , SDM845_SLAVE_PDM , SDM845_SLAVE_SOUTH_PHY_CFG , SDM845_SLAVE_PIMEM_CFG , SDM845_SLAVE_PRNG , SDM845_SLAVE_QDSS_CFG , SDM845_SLAVE_BLSP_2 , SDM845_SLAVE_BLSP_1 , SDM845_SLAVE_SDCC_2 , SDM845_SLAVE_SDCC_4 , SDM845_SLAVE_SNOC_CFG , SDM845_SLAVE_SPDM_WRAPPER , SDM845_SLAVE_SPSS_CFG , SDM845_SLAVE_TCSR , SDM845_SLAVE_TLMM_NORTH , SDM845_SLAVE_TLMM_SOUTH , SDM845_SLAVE_TSIF , SDM845_SLAVE_UFS_CARD_CFG , SDM845_SLAVE_UFS_MEM_CFG , SDM845_SLAVE_USB3_0 , SDM845_SLAVE_USB3_1 , SDM845_SLAVE_VENUS_CFG , SDM845_SLAVE_VSENSE_CTRL_CFG , SDM845_SLAVE_SERVICE_CNOC ) ;
DEFINE_QNODE ( xm_qdss_dap , SDM845_MASTER_QDSS_DAP , 1 , 8 , SDM845_SLAVE_A1NOC_CFG , SDM845_SLAVE_A2NOC_CFG , SDM845_SLAVE_AOP , SDM845_SLAVE_AOSS , SDM845_SLAVE_CAMERA_CFG , SDM845_SLAVE_CLK_CTL , SDM845_SLAVE_CDSP_CFG , SDM845_SLAVE_RBCPR_CX_CFG , SDM845_SLAVE_CRYPTO_0_CFG , SDM845_SLAVE_DCC_CFG , SDM845_SLAVE_CNOC_DDRSS , SDM845_SLAVE_DISPLAY_CFG , SDM845_SLAVE_GLM , SDM845_SLAVE_GFX3D_CFG , SDM845_SLAVE_IMEM_CFG , SDM845_SLAVE_IPA_CFG , SDM845_SLAVE_CNOC_MNOC_CFG , SDM845_SLAVE_PCIE_0_CFG , SDM845_SLAVE_PCIE_1_CFG , SDM845_SLAVE_PDM , SDM845_SLAVE_SOUTH_PHY_CFG , SDM845_SLAVE_PIMEM_CFG , SDM845_SLAVE_PRNG , SDM845_SLAVE_QDSS_CFG , SDM845_SLAVE_BLSP_2 , SDM845_SLAVE_BLSP_1 , SDM845_SLAVE_SDCC_2 , SDM845_SLAVE_SDCC_4 , SDM845_SLAVE_SNOC_CFG , SDM845_SLAVE_SPDM_WRAPPER , SDM845_SLAVE_SPSS_CFG , SDM845_SLAVE_TCSR , SDM845_SLAVE_TLMM_NORTH , SDM845_SLAVE_TLMM_SOUTH , SDM845_SLAVE_TSIF , SDM845_SLAVE_UFS_CARD_CFG , SDM845_SLAVE_UFS_MEM_CFG , SDM845_SLAVE_USB3_0 , SDM845_SLAVE_USB3_1 , SDM845_SLAVE_VENUS_CFG , SDM845_SLAVE_VSENSE_CTRL_CFG , SDM845_SLAVE_CNOC_A2NOC , SDM845_SLAVE_SERVICE_CNOC ) ;
DEFINE_QNODE ( qhm_cnoc , SDM845_MASTER_CNOC_DC_NOC , 1 , 4 , SDM845_SLAVE_LLCC_CFG , SDM845_SLAVE_MEM_NOC_CFG ) ;
DEFINE_QNODE ( acm_l3 , SDM845_MASTER_APPSS_PROC , 1 , 16 , SDM845_SLAVE_GNOC_SNOC , SDM845_SLAVE_GNOC_MEM_NOC , SDM845_SLAVE_SERVICE_GNOC ) ;
DEFINE_QNODE ( pm_gnoc_cfg , SDM845_MASTER_GNOC_CFG , 1 , 4 , SDM845_SLAVE_SERVICE_GNOC ) ;
DEFINE_QNODE ( llcc_mc , SDM845_MASTER_LLCC , 4 , 4 , SDM845_SLAVE_EBI1 ) ;
DEFINE_QNODE ( acm_tcu , SDM845_MASTER_TCU_0 , 1 , 8 , SDM845_SLAVE_MEM_NOC_GNOC , SDM845_SLAVE_LLCC , SDM845_SLAVE_MEM_NOC_SNOC ) ;
DEFINE_QNODE ( qhm_memnoc_cfg , SDM845_MASTER_MEM_NOC_CFG , 1 , 4 , SDM845_SLAVE_MSS_PROC_MS_MPU_CFG , SDM845_SLAVE_SERVICE_MEM_NOC ) ;
DEFINE_QNODE ( qnm_apps , SDM845_MASTER_GNOC_MEM_NOC , 2 , 32 , SDM845_SLAVE_LLCC ) ;
DEFINE_QNODE ( qnm_mnoc_hf , SDM845_MASTER_MNOC_HF_MEM_NOC , 2 , 32 , SDM845_SLAVE_MEM_NOC_GNOC , SDM845_SLAVE_LLCC ) ;
DEFINE_QNODE ( qnm_mnoc_sf , SDM845_MASTER_MNOC_SF_MEM_NOC , 1 , 32 , SDM845_SLAVE_MEM_NOC_GNOC , SDM845_SLAVE_LLCC , SDM845_SLAVE_MEM_NOC_SNOC ) ;
DEFINE_QNODE ( qnm_snoc_gc , SDM845_MASTER_SNOC_GC_MEM_NOC , 1 , 8 , SDM845_SLAVE_LLCC ) ;
DEFINE_QNODE ( qnm_snoc_sf , SDM845_MASTER_SNOC_SF_MEM_NOC , 1 , 16 , SDM845_SLAVE_MEM_NOC_GNOC , SDM845_SLAVE_LLCC ) ;
DEFINE_QNODE ( qxm_gpu , SDM845_MASTER_GFX3D , 2 , 32 , SDM845_SLAVE_MEM_NOC_GNOC , SDM845_SLAVE_LLCC , SDM845_SLAVE_MEM_NOC_SNOC ) ;
DEFINE_QNODE ( qhm_mnoc_cfg , SDM845_MASTER_CNOC_MNOC_CFG , 1 , 4 , SDM845_SLAVE_SERVICE_MNOC ) ;
DEFINE_QNODE ( qxm_camnoc_hf0 , SDM845_MASTER_CAMNOC_HF0 , 1 , 32 , SDM845_SLAVE_MNOC_HF_MEM_NOC ) ;
DEFINE_QNODE ( qxm_camnoc_hf1 , SDM845_MASTER_CAMNOC_HF1 , 1 , 32 , SDM845_SLAVE_MNOC_HF_MEM_NOC ) ;
DEFINE_QNODE ( qxm_camnoc_sf , SDM845_MASTER_CAMNOC_SF , 1 , 32 , SDM845_SLAVE_MNOC_SF_MEM_NOC ) ;
DEFINE_QNODE ( qxm_mdp0 , SDM845_MASTER_MDP0 , 1 , 32 , SDM845_SLAVE_MNOC_HF_MEM_NOC ) ;
DEFINE_QNODE ( qxm_mdp1 , SDM845_MASTER_MDP1 , 1 , 32 , SDM845_SLAVE_MNOC_HF_MEM_NOC ) ;
DEFINE_QNODE ( qxm_rot , SDM845_MASTER_ROTATOR , 1 , 32 , SDM845_SLAVE_MNOC_SF_MEM_NOC ) ;
DEFINE_QNODE ( qxm_venus0 , SDM845_MASTER_VIDEO_P0 , 1 , 32 , SDM845_SLAVE_MNOC_SF_MEM_NOC ) ;
DEFINE_QNODE ( qxm_venus1 , SDM845_MASTER_VIDEO_P1 , 1 , 32 , SDM845_SLAVE_MNOC_SF_MEM_NOC ) ;
DEFINE_QNODE ( qxm_venus_arm9 , SDM845_MASTER_VIDEO_PROC , 1 , 8 , SDM845_SLAVE_MNOC_SF_MEM_NOC ) ;
DEFINE_QNODE ( qhm_snoc_cfg , SDM845_MASTER_SNOC_CFG , 1 , 4 , SDM845_SLAVE_SERVICE_SNOC ) ;
DEFINE_QNODE ( qnm_aggre1_noc , SDM845_MASTER_A1NOC_SNOC , 1 , 16 , SDM845_SLAVE_APPSS , SDM845_SLAVE_SNOC_CNOC , SDM845_SLAVE_SNOC_MEM_NOC_SF , SDM845_SLAVE_IMEM , SDM845_SLAVE_PIMEM , SDM845_SLAVE_QDSS_STM ) ;
DEFINE_QNODE ( qnm_aggre2_noc , SDM845_MASTER_A2NOC_SNOC , 1 , 16 , SDM845_SLAVE_APPSS , SDM845_SLAVE_SNOC_CNOC , SDM845_SLAVE_SNOC_MEM_NOC_SF , SDM845_SLAVE_IMEM , SDM845_SLAVE_PCIE_0 , SDM845_SLAVE_PCIE_1 , SDM845_SLAVE_PIMEM , SDM845_SLAVE_QDSS_STM , SDM845_SLAVE_TCU ) ;
DEFINE_QNODE ( qnm_gladiator_sodv , SDM845_MASTER_GNOC_SNOC , 1 , 8 , SDM845_SLAVE_APPSS , SDM845_SLAVE_SNOC_CNOC , SDM845_SLAVE_IMEM , SDM845_SLAVE_PCIE_0 , SDM845_SLAVE_PCIE_1 , SDM845_SLAVE_PIMEM , SDM845_SLAVE_QDSS_STM , SDM845_SLAVE_TCU ) ;
DEFINE_QNODE ( qnm_memnoc , SDM845_MASTER_MEM_NOC_SNOC , 1 , 8 , SDM845_SLAVE_APPSS , SDM845_SLAVE_SNOC_CNOC , SDM845_SLAVE_IMEM , SDM845_SLAVE_PIMEM , SDM845_SLAVE_QDSS_STM ) ;
DEFINE_QNODE ( qnm_pcie_anoc , SDM845_MASTER_ANOC_PCIE_SNOC , 1 , 16 , SDM845_SLAVE_APPSS , SDM845_SLAVE_SNOC_CNOC , SDM845_SLAVE_SNOC_MEM_NOC_SF , SDM845_SLAVE_IMEM , SDM845_SLAVE_QDSS_STM ) ;
DEFINE_QNODE ( qxm_pimem , SDM845_MASTER_PIMEM , 1 , 8 , SDM845_SLAVE_SNOC_MEM_NOC_GC , SDM845_SLAVE_IMEM ) ;
DEFINE_QNODE ( xm_gic , SDM845_MASTER_GIC , 1 , 8 , SDM845_SLAVE_SNOC_MEM_NOC_GC , SDM845_SLAVE_IMEM ) ;
DEFINE_QNODE ( qns_a1noc_snoc , SDM845_SLAVE_A1NOC_SNOC , 1 , 16 , SDM845_MASTER_A1NOC_SNOC ) ;
DEFINE_QNODE ( srvc_aggre1_noc , SDM845_SLAVE_SERVICE_A1NOC , 1 , 4 , 0 ) ;
DEFINE_QNODE ( qns_pcie_a1noc_snoc , SDM845_SLAVE_ANOC_PCIE_A1NOC_SNOC , 1 , 16 , SDM845_MASTER_ANOC_PCIE_SNOC ) ;
DEFINE_QNODE ( qns_a2noc_snoc , SDM845_SLAVE_A2NOC_SNOC , 1 , 16 , SDM845_MASTER_A2NOC_SNOC ) ;
DEFINE_QNODE ( qns_pcie_snoc , SDM845_SLAVE_ANOC_PCIE_SNOC , 1 , 16 , SDM845_MASTER_ANOC_PCIE_SNOC ) ;
DEFINE_QNODE ( srvc_aggre2_noc , SDM845_SLAVE_SERVICE_A2NOC , 1 , 4 ) ;
DEFINE_QNODE ( qns_camnoc_uncomp , SDM845_SLAVE_CAMNOC_UNCOMP , 1 , 32 ) ;
DEFINE_QNODE ( qhs_a1_noc_cfg , SDM845_SLAVE_A1NOC_CFG , 1 , 4 , SDM845_MASTER_A1NOC_CFG ) ;
DEFINE_QNODE ( qhs_a2_noc_cfg , SDM845_SLAVE_A2NOC_CFG , 1 , 4 , SDM845_MASTER_A2NOC_CFG ) ;
DEFINE_QNODE ( qhs_aop , SDM845_SLAVE_AOP , 1 , 4 ) ;
DEFINE_QNODE ( qhs_aoss , SDM845_SLAVE_AOSS , 1 , 4 ) ;
DEFINE_QNODE ( qhs_camera_cfg , SDM845_SLAVE_CAMERA_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_clk_ctl , SDM845_SLAVE_CLK_CTL , 1 , 4 ) ;
DEFINE_QNODE ( qhs_compute_dsp_cfg , SDM845_SLAVE_CDSP_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_cpr_cx , SDM845_SLAVE_RBCPR_CX_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_crypto0_cfg , SDM845_SLAVE_CRYPTO_0_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_dcc_cfg , SDM845_SLAVE_DCC_CFG , 1 , 4 , SDM845_MASTER_CNOC_DC_NOC ) ;
DEFINE_QNODE ( qhs_ddrss_cfg , SDM845_SLAVE_CNOC_DDRSS , 1 , 4 ) ;
DEFINE_QNODE ( qhs_display_cfg , SDM845_SLAVE_DISPLAY_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_glm , SDM845_SLAVE_GLM , 1 , 4 ) ;
DEFINE_QNODE ( qhs_gpuss_cfg , SDM845_SLAVE_GFX3D_CFG , 1 , 8 ) ;
DEFINE_QNODE ( qhs_imem_cfg , SDM845_SLAVE_IMEM_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_ipa , SDM845_SLAVE_IPA_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_mnoc_cfg , SDM845_SLAVE_CNOC_MNOC_CFG , 1 , 4 , SDM845_MASTER_CNOC_MNOC_CFG ) ;
DEFINE_QNODE ( qhs_pcie0_cfg , SDM845_SLAVE_PCIE_0_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_pcie_gen3_cfg , SDM845_SLAVE_PCIE_1_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_pdm , SDM845_SLAVE_PDM , 1 , 4 ) ;
DEFINE_QNODE ( qhs_phy_refgen_south , SDM845_SLAVE_SOUTH_PHY_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_pimem_cfg , SDM845_SLAVE_PIMEM_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_prng , SDM845_SLAVE_PRNG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_qdss_cfg , SDM845_SLAVE_QDSS_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_qupv3_north , SDM845_SLAVE_BLSP_2 , 1 , 4 ) ;
DEFINE_QNODE ( qhs_qupv3_south , SDM845_SLAVE_BLSP_1 , 1 , 4 ) ;
DEFINE_QNODE ( qhs_sdc2 , SDM845_SLAVE_SDCC_2 , 1 , 4 ) ;
DEFINE_QNODE ( qhs_sdc4 , SDM845_SLAVE_SDCC_4 , 1 , 4 ) ;
DEFINE_QNODE ( qhs_snoc_cfg , SDM845_SLAVE_SNOC_CFG , 1 , 4 , SDM845_MASTER_SNOC_CFG ) ;
DEFINE_QNODE ( qhs_spdm , SDM845_SLAVE_SPDM_WRAPPER , 1 , 4 ) ;
DEFINE_QNODE ( qhs_spss_cfg , SDM845_SLAVE_SPSS_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_tcsr , SDM845_SLAVE_TCSR , 1 , 4 ) ;
DEFINE_QNODE ( qhs_tlmm_north , SDM845_SLAVE_TLMM_NORTH , 1 , 4 ) ;
DEFINE_QNODE ( qhs_tlmm_south , SDM845_SLAVE_TLMM_SOUTH , 1 , 4 ) ;
DEFINE_QNODE ( qhs_tsif , SDM845_SLAVE_TSIF , 1 , 4 ) ;
DEFINE_QNODE ( qhs_ufs_card_cfg , SDM845_SLAVE_UFS_CARD_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_ufs_mem_cfg , SDM845_SLAVE_UFS_MEM_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_usb3_0 , SDM845_SLAVE_USB3_0 , 1 , 4 ) ;
DEFINE_QNODE ( qhs_usb3_1 , SDM845_SLAVE_USB3_1 , 1 , 4 ) ;
DEFINE_QNODE ( qhs_venus_cfg , SDM845_SLAVE_VENUS_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_vsense_ctrl_cfg , SDM845_SLAVE_VSENSE_CTRL_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qns_cnoc_a2noc , SDM845_SLAVE_CNOC_A2NOC , 1 , 8 , SDM845_MASTER_CNOC_A2NOC ) ;
DEFINE_QNODE ( srvc_cnoc , SDM845_SLAVE_SERVICE_CNOC , 1 , 4 ) ;
DEFINE_QNODE ( qhs_llcc , SDM845_SLAVE_LLCC_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qhs_memnoc , SDM845_SLAVE_MEM_NOC_CFG , 1 , 4 , SDM845_MASTER_MEM_NOC_CFG ) ;
DEFINE_QNODE ( qns_gladiator_sodv , SDM845_SLAVE_GNOC_SNOC , 1 , 8 , SDM845_MASTER_GNOC_SNOC ) ;
DEFINE_QNODE ( qns_gnoc_memnoc , SDM845_SLAVE_GNOC_MEM_NOC , 2 , 32 , SDM845_MASTER_GNOC_MEM_NOC ) ;
DEFINE_QNODE ( srvc_gnoc , SDM845_SLAVE_SERVICE_GNOC , 1 , 4 ) ;
DEFINE_QNODE ( ebi , SDM845_SLAVE_EBI1 , 4 , 4 ) ;
DEFINE_QNODE ( qhs_mdsp_ms_mpu_cfg , SDM845_SLAVE_MSS_PROC_MS_MPU_CFG , 1 , 4 ) ;
DEFINE_QNODE ( qns_apps_io , SDM845_SLAVE_MEM_NOC_GNOC , 1 , 32 ) ;
DEFINE_QNODE ( qns_llcc , SDM845_SLAVE_LLCC , 4 , 16 , SDM845_MASTER_LLCC ) ;
DEFINE_QNODE ( qns_memnoc_snoc , SDM845_SLAVE_MEM_NOC_SNOC , 1 , 8 , SDM845_MASTER_MEM_NOC_SNOC ) ;
DEFINE_QNODE ( srvc_memnoc , SDM845_SLAVE_SERVICE_MEM_NOC , 1 , 4 ) ;
DEFINE_QNODE ( qns2_mem_noc , SDM845_SLAVE_MNOC_SF_MEM_NOC , 1 , 32 , SDM845_MASTER_MNOC_SF_MEM_NOC ) ;
DEFINE_QNODE ( qns_mem_noc_hf , SDM845_SLAVE_MNOC_HF_MEM_NOC , 2 , 32 , SDM845_MASTER_MNOC_HF_MEM_NOC ) ;
DEFINE_QNODE ( srvc_mnoc , SDM845_SLAVE_SERVICE_MNOC , 1 , 4 ) ;
DEFINE_QNODE ( qhs_apss , SDM845_SLAVE_APPSS , 1 , 8 ) ;
DEFINE_QNODE ( qns_cnoc , SDM845_SLAVE_SNOC_CNOC , 1 , 8 , SDM845_MASTER_SNOC_CNOC ) ;
DEFINE_QNODE ( qns_memnoc_gc , SDM845_SLAVE_SNOC_MEM_NOC_GC , 1 , 8 , SDM845_MASTER_SNOC_GC_MEM_NOC ) ;
DEFINE_QNODE ( qns_memnoc_sf , SDM845_SLAVE_SNOC_MEM_NOC_SF , 1 , 16 , SDM845_MASTER_SNOC_SF_MEM_NOC ) ;
DEFINE_QNODE ( qxs_imem , SDM845_SLAVE_IMEM , 1 , 8 ) ;
DEFINE_QNODE ( qxs_pcie , SDM845_SLAVE_PCIE_0 , 1 , 8 ) ;
DEFINE_QNODE ( qxs_pcie_gen3 , SDM845_SLAVE_PCIE_1 , 1 , 8 ) ;
DEFINE_QNODE ( qxs_pimem , SDM845_SLAVE_PIMEM , 1 , 8 ) ;
DEFINE_QNODE ( srvc_snoc , SDM845_SLAVE_SERVICE_SNOC , 1 , 4 ) ;
DEFINE_QNODE ( xs_qdss_stm , SDM845_SLAVE_QDSS_STM , 1 , 4 ) ;
DEFINE_QNODE ( xs_sys_tcu_cfg , SDM845_SLAVE_TCU , 1 , 8 ) ;
DEFINE_QBCM ( bcm_acv , " ACV " , false , & ebi ) ;
DEFINE_QBCM ( bcm_mc0 , " MC0 " , true , & ebi ) ;
DEFINE_QBCM ( bcm_sh0 , " SH0 " , true , & qns_llcc ) ;
DEFINE_QBCM ( bcm_mm0 , " MM0 " , false , & qns_mem_noc_hf ) ;
DEFINE_QBCM ( bcm_sh1 , " SH1 " , false , & qns_apps_io ) ;
2020-10-12 22:40:34 +03:00
DEFINE_QBCM ( bcm_mm1 , " MM1 " , true , & qxm_camnoc_hf0_uncomp , & qxm_camnoc_hf1_uncomp , & qxm_camnoc_sf_uncomp , & qxm_camnoc_hf0 , & qxm_camnoc_hf1 , & qxm_mdp0 , & qxm_mdp1 ) ;
2020-02-28 12:11:40 +02:00
DEFINE_QBCM ( bcm_sh2 , " SH2 " , false , & qns_memnoc_snoc ) ;
DEFINE_QBCM ( bcm_mm2 , " MM2 " , false , & qns2_mem_noc ) ;
DEFINE_QBCM ( bcm_sh3 , " SH3 " , false , & acm_tcu ) ;
DEFINE_QBCM ( bcm_mm3 , " MM3 " , false , & qxm_camnoc_sf , & qxm_rot , & qxm_venus0 , & qxm_venus1 , & qxm_venus_arm9 ) ;
DEFINE_QBCM ( bcm_sh5 , " SH5 " , false , & qnm_apps ) ;
DEFINE_QBCM ( bcm_sn0 , " SN0 " , true , & qns_memnoc_sf ) ;
DEFINE_QBCM ( bcm_ce0 , " CE0 " , false , & qxm_crypto ) ;
DEFINE_QBCM ( bcm_cn0 , " CN0 " , false , & qhm_spdm , & qhm_tic , & qnm_snoc , & xm_qdss_dap , & qhs_a1_noc_cfg , & qhs_a2_noc_cfg , & qhs_aop , & qhs_aoss , & qhs_camera_cfg , & qhs_clk_ctl , & qhs_compute_dsp_cfg , & qhs_cpr_cx , & qhs_crypto0_cfg , & qhs_dcc_cfg , & qhs_ddrss_cfg , & qhs_display_cfg , & qhs_glm , & qhs_gpuss_cfg , & qhs_imem_cfg , & qhs_ipa , & qhs_mnoc_cfg , & qhs_pcie0_cfg , & qhs_pcie_gen3_cfg , & qhs_pdm , & qhs_phy_refgen_south , & qhs_pimem_cfg , & qhs_prng , & qhs_qdss_cfg , & qhs_qupv3_north , & qhs_qupv3_south , & qhs_sdc2 , & qhs_sdc4 , & qhs_snoc_cfg , & qhs_spdm , & qhs_spss_cfg , & qhs_tcsr , & qhs_tlmm_north , & qhs_tlmm_south , & qhs_tsif , & qhs_ufs_card_cfg , & qhs_ufs_mem_cfg , & qhs_usb3_0 , & qhs_usb3_1 , & qhs_venus_cfg , & qhs_vsense_ctrl_cfg , & qns_cnoc_a2noc , & srvc_cnoc ) ;
DEFINE_QBCM ( bcm_qup0 , " QUP0 " , false , & qhm_qup1 , & qhm_qup2 ) ;
DEFINE_QBCM ( bcm_sn1 , " SN1 " , false , & qxs_imem ) ;
DEFINE_QBCM ( bcm_sn2 , " SN2 " , false , & qns_memnoc_gc ) ;
DEFINE_QBCM ( bcm_sn3 , " SN3 " , false , & qns_cnoc ) ;
DEFINE_QBCM ( bcm_sn4 , " SN4 " , false , & qxm_pimem ) ;
DEFINE_QBCM ( bcm_sn5 , " SN5 " , false , & xs_qdss_stm ) ;
DEFINE_QBCM ( bcm_sn6 , " SN6 " , false , & qhs_apss , & srvc_snoc , & xs_sys_tcu_cfg ) ;
DEFINE_QBCM ( bcm_sn7 , " SN7 " , false , & qxs_pcie ) ;
DEFINE_QBCM ( bcm_sn8 , " SN8 " , false , & qxs_pcie_gen3 ) ;
DEFINE_QBCM ( bcm_sn9 , " SN9 " , false , & srvc_aggre1_noc , & qnm_aggre1_noc ) ;
DEFINE_QBCM ( bcm_sn11 , " SN11 " , false , & srvc_aggre2_noc , & qnm_aggre2_noc ) ;
DEFINE_QBCM ( bcm_sn12 , " SN12 " , false , & qnm_gladiator_sodv , & xm_gic ) ;
DEFINE_QBCM ( bcm_sn14 , " SN14 " , false , & qnm_pcie_anoc ) ;
DEFINE_QBCM ( bcm_sn15 , " SN15 " , false , & qnm_memnoc ) ;
static struct qcom_icc_bcm * aggre1_noc_bcms [ ] = {
& bcm_sn9 ,
2020-11-05 15:52:10 +02:00
& bcm_qup0 ,
2019-01-16 18:11:00 +02:00
} ;
2020-02-28 12:11:40 +02:00
static struct qcom_icc_node * aggre1_noc_nodes [ ] = {
[ MASTER_A1NOC_CFG ] = & qhm_a1noc_cfg ,
[ MASTER_TSIF ] = & qhm_tsif ,
[ MASTER_SDCC_2 ] = & xm_sdc2 ,
[ MASTER_SDCC_4 ] = & xm_sdc4 ,
[ MASTER_UFS_CARD ] = & xm_ufs_card ,
[ MASTER_UFS_MEM ] = & xm_ufs_mem ,
[ MASTER_PCIE_0 ] = & xm_pcie_0 ,
[ SLAVE_A1NOC_SNOC ] = & qns_a1noc_snoc ,
[ SLAVE_SERVICE_A1NOC ] = & srvc_aggre1_noc ,
[ SLAVE_ANOC_PCIE_A1NOC_SNOC ] = & qns_pcie_a1noc_snoc ,
2020-11-05 15:52:10 +02:00
[ MASTER_QUP_1 ] = & qhm_qup1 ,
2019-01-16 18:11:00 +02:00
} ;
2020-04-29 13:19:04 +03:00
static const struct qcom_icc_desc sdm845_aggre1_noc = {
2020-02-28 12:11:40 +02:00
. nodes = aggre1_noc_nodes ,
. num_nodes = ARRAY_SIZE ( aggre1_noc_nodes ) ,
. bcms = aggre1_noc_bcms ,
. num_bcms = ARRAY_SIZE ( aggre1_noc_bcms ) ,
2019-01-16 18:11:00 +02:00
} ;
2020-02-28 12:11:40 +02:00
static struct qcom_icc_bcm * aggre2_noc_bcms [ ] = {
& bcm_ce0 ,
& bcm_sn11 ,
& bcm_qup0 ,
} ;
2019-01-16 18:11:00 +02:00
2020-02-28 12:11:40 +02:00
static struct qcom_icc_node * aggre2_noc_nodes [ ] = {
2019-01-16 18:11:00 +02:00
[ MASTER_A2NOC_CFG ] = & qhm_a2noc_cfg ,
[ MASTER_QDSS_BAM ] = & qhm_qdss_bam ,
[ MASTER_CNOC_A2NOC ] = & qnm_cnoc ,
[ MASTER_CRYPTO ] = & qxm_crypto ,
[ MASTER_IPA ] = & qxm_ipa ,
[ MASTER_PCIE_1 ] = & xm_pcie3_1 ,
[ MASTER_QDSS_ETR ] = & xm_qdss_etr ,
[ MASTER_USB3_0 ] = & xm_usb3_0 ,
[ MASTER_USB3_1 ] = & xm_usb3_1 ,
2020-02-28 12:11:40 +02:00
[ SLAVE_A2NOC_SNOC ] = & qns_a2noc_snoc ,
[ SLAVE_ANOC_PCIE_SNOC ] = & qns_pcie_snoc ,
[ SLAVE_SERVICE_A2NOC ] = & srvc_aggre2_noc ,
2020-11-05 15:52:10 +02:00
[ MASTER_QUP_2 ] = & qhm_qup2 ,
2020-02-28 12:11:40 +02:00
} ;
2020-04-29 13:19:04 +03:00
static const struct qcom_icc_desc sdm845_aggre2_noc = {
2020-02-28 12:11:40 +02:00
. nodes = aggre2_noc_nodes ,
. num_nodes = ARRAY_SIZE ( aggre2_noc_nodes ) ,
. bcms = aggre2_noc_bcms ,
. num_bcms = ARRAY_SIZE ( aggre2_noc_bcms ) ,
} ;
static struct qcom_icc_bcm * config_noc_bcms [ ] = {
& bcm_cn0 ,
} ;
static struct qcom_icc_node * config_noc_nodes [ ] = {
[ MASTER_SPDM ] = & qhm_spdm ,
[ MASTER_TIC ] = & qhm_tic ,
[ MASTER_SNOC_CNOC ] = & qnm_snoc ,
[ MASTER_QDSS_DAP ] = & xm_qdss_dap ,
2019-01-16 18:11:00 +02:00
[ SLAVE_A1NOC_CFG ] = & qhs_a1_noc_cfg ,
[ SLAVE_A2NOC_CFG ] = & qhs_a2_noc_cfg ,
[ SLAVE_AOP ] = & qhs_aop ,
[ SLAVE_AOSS ] = & qhs_aoss ,
[ SLAVE_CAMERA_CFG ] = & qhs_camera_cfg ,
[ SLAVE_CLK_CTL ] = & qhs_clk_ctl ,
[ SLAVE_CDSP_CFG ] = & qhs_compute_dsp_cfg ,
[ SLAVE_RBCPR_CX_CFG ] = & qhs_cpr_cx ,
[ SLAVE_CRYPTO_0_CFG ] = & qhs_crypto0_cfg ,
[ SLAVE_DCC_CFG ] = & qhs_dcc_cfg ,
[ SLAVE_CNOC_DDRSS ] = & qhs_ddrss_cfg ,
[ SLAVE_DISPLAY_CFG ] = & qhs_display_cfg ,
[ SLAVE_GLM ] = & qhs_glm ,
[ SLAVE_GFX3D_CFG ] = & qhs_gpuss_cfg ,
[ SLAVE_IMEM_CFG ] = & qhs_imem_cfg ,
[ SLAVE_IPA_CFG ] = & qhs_ipa ,
[ SLAVE_CNOC_MNOC_CFG ] = & qhs_mnoc_cfg ,
[ SLAVE_PCIE_0_CFG ] = & qhs_pcie0_cfg ,
[ SLAVE_PCIE_1_CFG ] = & qhs_pcie_gen3_cfg ,
[ SLAVE_PDM ] = & qhs_pdm ,
[ SLAVE_SOUTH_PHY_CFG ] = & qhs_phy_refgen_south ,
[ SLAVE_PIMEM_CFG ] = & qhs_pimem_cfg ,
[ SLAVE_PRNG ] = & qhs_prng ,
[ SLAVE_QDSS_CFG ] = & qhs_qdss_cfg ,
[ SLAVE_BLSP_2 ] = & qhs_qupv3_north ,
[ SLAVE_BLSP_1 ] = & qhs_qupv3_south ,
[ SLAVE_SDCC_2 ] = & qhs_sdc2 ,
[ SLAVE_SDCC_4 ] = & qhs_sdc4 ,
[ SLAVE_SNOC_CFG ] = & qhs_snoc_cfg ,
[ SLAVE_SPDM_WRAPPER ] = & qhs_spdm ,
[ SLAVE_SPSS_CFG ] = & qhs_spss_cfg ,
[ SLAVE_TCSR ] = & qhs_tcsr ,
[ SLAVE_TLMM_NORTH ] = & qhs_tlmm_north ,
[ SLAVE_TLMM_SOUTH ] = & qhs_tlmm_south ,
[ SLAVE_TSIF ] = & qhs_tsif ,
[ SLAVE_UFS_CARD_CFG ] = & qhs_ufs_card_cfg ,
[ SLAVE_UFS_MEM_CFG ] = & qhs_ufs_mem_cfg ,
[ SLAVE_USB3_0 ] = & qhs_usb3_0 ,
[ SLAVE_USB3_1 ] = & qhs_usb3_1 ,
[ SLAVE_VENUS_CFG ] = & qhs_venus_cfg ,
[ SLAVE_VSENSE_CTRL_CFG ] = & qhs_vsense_ctrl_cfg ,
[ SLAVE_CNOC_A2NOC ] = & qns_cnoc_a2noc ,
2020-02-28 12:11:40 +02:00
[ SLAVE_SERVICE_CNOC ] = & srvc_cnoc ,
} ;
2020-04-29 13:19:04 +03:00
static const struct qcom_icc_desc sdm845_config_noc = {
2020-02-28 12:11:40 +02:00
. nodes = config_noc_nodes ,
. num_nodes = ARRAY_SIZE ( config_noc_nodes ) ,
. bcms = config_noc_bcms ,
. num_bcms = ARRAY_SIZE ( config_noc_bcms ) ,
} ;
static struct qcom_icc_bcm * dc_noc_bcms [ ] = {
} ;
static struct qcom_icc_node * dc_noc_nodes [ ] = {
[ MASTER_CNOC_DC_NOC ] = & qhm_cnoc ,
[ SLAVE_LLCC_CFG ] = & qhs_llcc ,
[ SLAVE_MEM_NOC_CFG ] = & qhs_memnoc ,
} ;
2020-04-29 13:19:04 +03:00
static const struct qcom_icc_desc sdm845_dc_noc = {
2020-02-28 12:11:40 +02:00
. nodes = dc_noc_nodes ,
. num_nodes = ARRAY_SIZE ( dc_noc_nodes ) ,
. bcms = dc_noc_bcms ,
. num_bcms = ARRAY_SIZE ( dc_noc_bcms ) ,
} ;
static struct qcom_icc_bcm * gladiator_noc_bcms [ ] = {
} ;
static struct qcom_icc_node * gladiator_noc_nodes [ ] = {
[ MASTER_APPSS_PROC ] = & acm_l3 ,
[ MASTER_GNOC_CFG ] = & pm_gnoc_cfg ,
2019-01-16 18:11:00 +02:00
[ SLAVE_GNOC_SNOC ] = & qns_gladiator_sodv ,
[ SLAVE_GNOC_MEM_NOC ] = & qns_gnoc_memnoc ,
[ SLAVE_SERVICE_GNOC ] = & srvc_gnoc ,
} ;
2020-04-29 13:19:04 +03:00
static const struct qcom_icc_desc sdm845_gladiator_noc = {
2020-02-28 12:11:40 +02:00
. nodes = gladiator_noc_nodes ,
. num_nodes = ARRAY_SIZE ( gladiator_noc_nodes ) ,
. bcms = gladiator_noc_bcms ,
. num_bcms = ARRAY_SIZE ( gladiator_noc_bcms ) ,
} ;
static struct qcom_icc_bcm * mem_noc_bcms [ ] = {
2019-01-16 18:11:00 +02:00
& bcm_mc0 ,
2020-02-28 12:11:40 +02:00
& bcm_acv ,
2019-01-16 18:11:00 +02:00
& bcm_sh0 ,
& bcm_sh1 ,
& bcm_sh2 ,
& bcm_sh3 ,
& bcm_sh5 ,
2020-02-28 12:11:40 +02:00
} ;
static struct qcom_icc_node * mem_noc_nodes [ ] = {
[ MASTER_TCU_0 ] = & acm_tcu ,
[ MASTER_MEM_NOC_CFG ] = & qhm_memnoc_cfg ,
[ MASTER_GNOC_MEM_NOC ] = & qnm_apps ,
[ MASTER_MNOC_HF_MEM_NOC ] = & qnm_mnoc_hf ,
[ MASTER_MNOC_SF_MEM_NOC ] = & qnm_mnoc_sf ,
[ MASTER_SNOC_GC_MEM_NOC ] = & qnm_snoc_gc ,
[ MASTER_SNOC_SF_MEM_NOC ] = & qnm_snoc_sf ,
[ MASTER_GFX3D ] = & qxm_gpu ,
[ SLAVE_MSS_PROC_MS_MPU_CFG ] = & qhs_mdsp_ms_mpu_cfg ,
[ SLAVE_MEM_NOC_GNOC ] = & qns_apps_io ,
[ SLAVE_LLCC ] = & qns_llcc ,
[ SLAVE_MEM_NOC_SNOC ] = & qns_memnoc_snoc ,
[ SLAVE_SERVICE_MEM_NOC ] = & srvc_memnoc ,
[ MASTER_LLCC ] = & llcc_mc ,
[ SLAVE_EBI1 ] = & ebi ,
} ;
2020-04-29 13:19:04 +03:00
static const struct qcom_icc_desc sdm845_mem_noc = {
2020-02-28 12:11:40 +02:00
. nodes = mem_noc_nodes ,
. num_nodes = ARRAY_SIZE ( mem_noc_nodes ) ,
. bcms = mem_noc_bcms ,
. num_bcms = ARRAY_SIZE ( mem_noc_bcms ) ,
} ;
static struct qcom_icc_bcm * mmss_noc_bcms [ ] = {
& bcm_mm0 ,
& bcm_mm1 ,
& bcm_mm2 ,
& bcm_mm3 ,
} ;
static struct qcom_icc_node * mmss_noc_nodes [ ] = {
[ MASTER_CNOC_MNOC_CFG ] = & qhm_mnoc_cfg ,
[ MASTER_CAMNOC_HF0 ] = & qxm_camnoc_hf0 ,
[ MASTER_CAMNOC_HF1 ] = & qxm_camnoc_hf1 ,
[ MASTER_CAMNOC_SF ] = & qxm_camnoc_sf ,
[ MASTER_MDP0 ] = & qxm_mdp0 ,
[ MASTER_MDP1 ] = & qxm_mdp1 ,
[ MASTER_ROTATOR ] = & qxm_rot ,
[ MASTER_VIDEO_P0 ] = & qxm_venus0 ,
[ MASTER_VIDEO_P1 ] = & qxm_venus1 ,
[ MASTER_VIDEO_PROC ] = & qxm_venus_arm9 ,
[ SLAVE_MNOC_SF_MEM_NOC ] = & qns2_mem_noc ,
[ SLAVE_MNOC_HF_MEM_NOC ] = & qns_mem_noc_hf ,
[ SLAVE_SERVICE_MNOC ] = & srvc_mnoc ,
[ MASTER_CAMNOC_HF0_UNCOMP ] = & qxm_camnoc_hf0_uncomp ,
[ MASTER_CAMNOC_HF1_UNCOMP ] = & qxm_camnoc_hf1_uncomp ,
[ MASTER_CAMNOC_SF_UNCOMP ] = & qxm_camnoc_sf_uncomp ,
[ SLAVE_CAMNOC_UNCOMP ] = & qns_camnoc_uncomp ,
} ;
2020-04-29 13:19:04 +03:00
static const struct qcom_icc_desc sdm845_mmss_noc = {
2020-02-28 12:11:40 +02:00
. nodes = mmss_noc_nodes ,
. num_nodes = ARRAY_SIZE ( mmss_noc_nodes ) ,
. bcms = mmss_noc_bcms ,
. num_bcms = ARRAY_SIZE ( mmss_noc_bcms ) ,
} ;
static struct qcom_icc_bcm * system_noc_bcms [ ] = {
2019-01-16 18:11:00 +02:00
& bcm_sn0 ,
& bcm_sn1 ,
& bcm_sn2 ,
& bcm_sn3 ,
& bcm_sn4 ,
& bcm_sn5 ,
& bcm_sn6 ,
& bcm_sn7 ,
& bcm_sn8 ,
& bcm_sn9 ,
& bcm_sn11 ,
& bcm_sn12 ,
& bcm_sn14 ,
& bcm_sn15 ,
} ;
2020-02-28 12:11:40 +02:00
static struct qcom_icc_node * system_noc_nodes [ ] = {
[ MASTER_SNOC_CFG ] = & qhm_snoc_cfg ,
[ MASTER_A1NOC_SNOC ] = & qnm_aggre1_noc ,
[ MASTER_A2NOC_SNOC ] = & qnm_aggre2_noc ,
[ MASTER_GNOC_SNOC ] = & qnm_gladiator_sodv ,
[ MASTER_MEM_NOC_SNOC ] = & qnm_memnoc ,
[ MASTER_ANOC_PCIE_SNOC ] = & qnm_pcie_anoc ,
[ MASTER_PIMEM ] = & qxm_pimem ,
[ MASTER_GIC ] = & xm_gic ,
[ SLAVE_APPSS ] = & qhs_apss ,
[ SLAVE_SNOC_CNOC ] = & qns_cnoc ,
[ SLAVE_SNOC_MEM_NOC_GC ] = & qns_memnoc_gc ,
[ SLAVE_SNOC_MEM_NOC_SF ] = & qns_memnoc_sf ,
[ SLAVE_IMEM ] = & qxs_imem ,
[ SLAVE_PCIE_0 ] = & qxs_pcie ,
[ SLAVE_PCIE_1 ] = & qxs_pcie_gen3 ,
[ SLAVE_PIMEM ] = & qxs_pimem ,
[ SLAVE_SERVICE_SNOC ] = & srvc_snoc ,
[ SLAVE_QDSS_STM ] = & xs_qdss_stm ,
[ SLAVE_TCU ] = & xs_sys_tcu_cfg ,
2019-01-16 18:11:00 +02:00
} ;
2020-04-29 13:19:04 +03:00
static const struct qcom_icc_desc sdm845_system_noc = {
2020-02-28 12:11:40 +02:00
. nodes = system_noc_nodes ,
. num_nodes = ARRAY_SIZE ( system_noc_nodes ) ,
. bcms = system_noc_bcms ,
. num_bcms = ARRAY_SIZE ( system_noc_bcms ) ,
} ;
2019-01-16 18:11:00 +02:00
static int qnoc_probe ( struct platform_device * pdev )
{
const struct qcom_icc_desc * desc ;
struct icc_onecell_data * data ;
struct icc_provider * provider ;
struct qcom_icc_node * * qnodes ;
struct qcom_icc_provider * qp ;
struct icc_node * node ;
size_t num_nodes , i ;
int ret ;
2020-02-28 12:11:40 +02:00
desc = device_get_match_data ( & pdev - > dev ) ;
2019-01-16 18:11:00 +02:00
if ( ! desc )
return - EINVAL ;
qnodes = desc - > nodes ;
num_nodes = desc - > num_nodes ;
qp = devm_kzalloc ( & pdev - > dev , sizeof ( * qp ) , GFP_KERNEL ) ;
if ( ! qp )
return - ENOMEM ;
2019-09-24 21:01:15 +03:00
data = devm_kzalloc ( & pdev - > dev , struct_size ( data , nodes , num_nodes ) ,
GFP_KERNEL ) ;
2019-01-16 18:11:00 +02:00
if ( ! data )
return - ENOMEM ;
provider = & qp - > provider ;
provider - > dev = & pdev - > dev ;
provider - > set = qcom_icc_set ;
2019-08-13 17:53:41 +03:00
provider - > pre_aggregate = qcom_icc_pre_aggregate ;
2019-01-16 18:11:00 +02:00
provider - > aggregate = qcom_icc_aggregate ;
2020-09-03 16:31:31 +03:00
provider - > xlate_extended = qcom_icc_xlate_extended ;
2019-01-16 18:11:00 +02:00
INIT_LIST_HEAD ( & provider - > nodes ) ;
provider - > data = data ;
qp - > dev = & pdev - > dev ;
qp - > bcms = desc - > bcms ;
qp - > num_bcms = desc - > num_bcms ;
2020-02-28 12:11:40 +02:00
qp - > voter = of_bcm_voter_get ( qp - > dev , NULL ) ;
if ( IS_ERR ( qp - > voter ) ) {
dev_err ( & pdev - > dev , " bcm_voter err:%ld \n " , PTR_ERR ( qp - > voter ) ) ;
return PTR_ERR ( qp - > voter ) ;
}
2019-01-16 18:11:00 +02:00
ret = icc_provider_add ( provider ) ;
if ( ret ) {
dev_err ( & pdev - > dev , " error adding interconnect provider \n " ) ;
return ret ;
}
2020-10-13 16:59:12 +03:00
for ( i = 0 ; i < qp - > num_bcms ; i + + )
qcom_icc_bcm_init ( qp - > bcms [ i ] , & pdev - > dev ) ;
2019-01-16 18:11:00 +02:00
for ( i = 0 ; i < num_nodes ; i + + ) {
size_t j ;
2020-02-28 12:11:40 +02:00
if ( ! qnodes [ i ] )
continue ;
2019-01-16 18:11:00 +02:00
node = icc_node_create ( qnodes [ i ] - > id ) ;
if ( IS_ERR ( node ) ) {
ret = PTR_ERR ( node ) ;
goto err ;
}
node - > name = qnodes [ i ] - > name ;
node - > data = qnodes [ i ] ;
icc_node_add ( node , provider ) ;
for ( j = 0 ; j < qnodes [ i ] - > num_links ; j + + )
icc_link_create ( node , qnodes [ i ] - > links [ j ] ) ;
data - > nodes [ i ] = node ;
}
data - > num_nodes = num_nodes ;
platform_set_drvdata ( pdev , qp ) ;
2020-02-28 12:11:40 +02:00
return 0 ;
2019-01-16 18:11:00 +02:00
err :
2019-12-02 18:21:33 +02:00
icc_nodes_remove ( provider ) ;
2019-01-16 18:11:00 +02:00
icc_provider_del ( provider ) ;
return ret ;
}
static int qnoc_remove ( struct platform_device * pdev )
{
struct qcom_icc_provider * qp = platform_get_drvdata ( pdev ) ;
2019-12-02 18:21:33 +02:00
icc_nodes_remove ( & qp - > provider ) ;
return icc_provider_del ( & qp - > provider ) ;
2019-01-16 18:11:00 +02:00
}
static const struct of_device_id qnoc_of_match [ ] = {
2020-02-28 12:11:40 +02:00
{ . compatible = " qcom,sdm845-aggre1-noc " ,
. data = & sdm845_aggre1_noc } ,
{ . compatible = " qcom,sdm845-aggre2-noc " ,
. data = & sdm845_aggre2_noc } ,
{ . compatible = " qcom,sdm845-config-noc " ,
. data = & sdm845_config_noc } ,
{ . compatible = " qcom,sdm845-dc-noc " ,
. data = & sdm845_dc_noc } ,
{ . compatible = " qcom,sdm845-gladiator-noc " ,
. data = & sdm845_gladiator_noc } ,
{ . compatible = " qcom,sdm845-mem-noc " ,
. data = & sdm845_mem_noc } ,
{ . compatible = " qcom,sdm845-mmss-noc " ,
. data = & sdm845_mmss_noc } ,
{ . compatible = " qcom,sdm845-system-noc " ,
. data = & sdm845_system_noc } ,
{ }
2019-01-16 18:11:00 +02:00
} ;
MODULE_DEVICE_TABLE ( of , qnoc_of_match ) ;
static struct platform_driver qnoc_driver = {
. probe = qnoc_probe ,
. remove = qnoc_remove ,
. driver = {
. name = " qnoc-sdm845 " ,
. of_match_table = qnoc_of_match ,
2020-08-25 20:01:52 +03:00
. sync_state = icc_sync_state ,
2019-01-16 18:11:00 +02:00
} ,
} ;
module_platform_driver ( qnoc_driver ) ;
MODULE_AUTHOR ( " David Dai <daidavid1@codeaurora.org> " ) ;
MODULE_DESCRIPTION ( " Qualcomm sdm845 NoC driver " ) ;
MODULE_LICENSE ( " GPL v2 " ) ;