// SPDX-License-Identifier: GPL-2.0-only
/*
* Based on data from msm8909-bus.dtsi in Qualcomm's msm-3.18 release:
* Copyright (c) 2014-2016, The Linux Foundation. All rights reserved.
*/
#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 <dt-bindings/interconnect/qcom,msm8909.h>
#include "icc-rpm.h"
enum {
QNOC_MASTER_AMPSS_M0 = 1,
QNOC_MASTER_GRAPHICS_3D,
QNOC_SNOC_BIMC_0_MAS,
QNOC_SNOC_BIMC_1_MAS,
QNOC_MASTER_TCU_0,
QNOC_MASTER_TCU_1,
QNOC_MASTER_AUDIO,
QNOC_MASTER_SPDM,
QNOC_MASTER_DEHR,
QNOC_MASTER_QPIC,
QNOC_MASTER_BLSP_1,
QNOC_MASTER_USB_HS,
QNOC_MASTER_CRYPTO_CORE0,
QNOC_MASTER_SDCC_1,
QNOC_MASTER_SDCC_2,
QNOC_SNOC_PNOC_MAS,
QNOC_MASTER_QDSS_BAM,
QNOC_BIMC_SNOC_MAS,
QNOC_MASTER_MDP_PORT0,
QNOC_PNOC_SNOC_MAS,
QNOC_MASTER_VIDEO_P0,
QNOC_MASTER_VFE,
QNOC_MASTER_QDSS_ETR,
QNOC_PNOC_M_0,
QNOC_PNOC_M_1,
QNOC_PNOC_INT_0,
QNOC_PNOC_INT_1,
QNOC_PNOC_SLV_0,
QNOC_PNOC_SLV_1,
QNOC_PNOC_SLV_2,
QNOC_PNOC_SLV_3,
QNOC_PNOC_SLV_4,
QNOC_PNOC_SLV_5,
QNOC_PNOC_SLV_7,
QNOC_SNOC_MM_INT_0,
QNOC_SNOC_MM_INT_1,
QNOC_SNOC_MM_INT_2,
QNOC_SNOC_MM_INT_BIMC,
QNOC_SNOC_QDSS_INT,
QNOC_SNOC_INT_0,
QNOC_SNOC_INT_1,
QNOC_SNOC_INT_BIMC,
QNOC_SLAVE_EBI_CH0,
QNOC_BIMC_SNOC_SLV,
QNOC_SLAVE_TCSR,
QNOC_SLAVE_SDCC_1,
QNOC_SLAVE_BLSP_1,
QNOC_SLAVE_CRYPTO_0_CFG,
QNOC_SLAVE_MESSAGE_RAM,
QNOC_SLAVE_PDM,
QNOC_SLAVE_PRNG,
QNOC_SLAVE_USB_HS,
QNOC_SLAVE_QPIC,
QNOC_SLAVE_SPDM,
QNOC_SLAVE_SDCC_2,
QNOC_SLAVE_AUDIO,
QNOC_SLAVE_DEHR_CFG,
QNOC_SLAVE_SNOC_CFG,
QNOC_SLAVE_QDSS_CFG,
QNOC_SLAVE_USB_PHYS_CFG,
QNOC_SLAVE_CAMERA_CFG,
QNOC_SLAVE_DISPLAY_CFG,
QNOC_SLAVE_VENUS_CFG,
QNOC_SLAVE_TLMM,
QNOC_SLAVE_GRAPHICS_3D_CFG,
QNOC_SLAVE_IMEM_CFG,
QNOC_SLAVE_BIMC_CFG,
QNOC_SLAVE_PMIC_ARB,
QNOC_SLAVE_TCU,
QNOC_PNOC_SNOC_SLV,
QNOC_SLAVE_APPSS,
QNOC_SNOC_BIMC_0_SLV,
QNOC_SNOC_BIMC_1_SLV,
QNOC_SLAVE_SYSTEM_IMEM,
QNOC_SNOC_PNOC_SLV,
QNOC_SLAVE_QDSS_STM,
QNOC_SLAVE_CATS_128,
QNOC_SLAVE_OCMEM_64,
};
static const u16 mas_apps_proc_links[] = {
QNOC_BIMC_SNOC_SLV,
QNOC_SLAVE_EBI_CH0
};
static struct qcom_icc_node mas_apps_proc = {
.name = "mas_apps_proc",
.id = QNOC_MASTER_AMPSS_M0,
.buswidth = 8,
.mas_rpm_id = 0,
.slv_rpm_id = -1,
.qos.ap_owned = true,
.qos.qos_mode = NOC_QOS_MODE_FIXED,
.qos.areq_prio = 0,
.qos.prio_level = 0,
.qos.qos_port = 0,
.num_links = ARRAY_SIZE(mas_apps_proc_links),
.links = mas_apps_proc_links,
};
static const u16 mas_oxili_links[] = {
QNOC_BIMC_SNOC_SLV,
QNOC_SLAVE_EBI_CH0
};
static struct qcom_icc_node mas_oxili = {
.name = "mas_oxili",
.id = QNOC_MASTER_GRAPHICS_3D,
.buswidth = 8,
.mas_rpm_id = 6,
.slv_rpm_id = -1,
.qos.ap_owned = true,
.qos.qos_mode = NOC_QOS_MODE_FIXED,
.qos.