mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-12-29 09:16:33 +00:00
31f1b03fbd
After commit 0edb555a65
("platform: Make platform_driver::remove()
return void") .remove() is (again) the right callback to implement for
platform drivers.
Convert all platform drivers below drivers/interconnect to use
.remove(), with the eventual goal to drop struct
platform_driver::remove_new(). As .remove() and .remove_new() have the
same prototypes, conversion is done by just changing the structure
member name in the driver initializer.
Signed-off-by: Uwe Kleine-König <u.kleine-koenig@baylibre.com>
Link: https://lore.kernel.org/r/20241017154920.136220-2-u.kleine-koenig@baylibre.com
Signed-off-by: Georgi Djakov <djakov@kernel.org>
1427 lines
32 KiB
C
1427 lines
32 KiB
C
// 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/device.h>
|
|
#include <linux/interconnect-provider.h>
|
|
#include <linux/mod_devicetable.h>
|
|
#include <linux/module.h>
|
|
#include <linux/platform_device.h>
|
|
#include <linux/regmap.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 = 22,
|
|
.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 = 4,
|
|
.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 = 9,
|
|
.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 = 13,
|
|
.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 = 10,
|
|
.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 = 5,
|
|
.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 = 8,
|
|
.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 = 20,
|
|
.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 = 2,
|
|
.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 = 0,
|
|
.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 = 3,
|
|
.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 = 12,
|
|
.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 = 17,
|
|
.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 = 23,
|
|
.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 = 24,
|
|
.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 * const 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 * const 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 * const 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,
|
|
.qos_offset = 0x15000,
|
|
.keep_alive = true,
|
|
};
|
|
|
|
static struct qcom_icc_node * const 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 * const 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,
|
|
.qos_offset = 0x15000,
|
|
.ab_coeff = 142,
|
|
};
|
|
|
|
static struct qcom_icc_node * const 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,
|
|
.qos_offset = 0x15000,
|
|
.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");
|