Merge tag 'sched-urgent-2024-03-24' of git://git.kernel.org/pub/scm/linux/kernel...
[sfrench/cifs-2.6.git] / drivers / interconnect / qcom / sm6115.c
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Copyright (c) 2021, The Linux Foundation. All rights reserved.
4  * Copyright (c) 2022, Qualcomm Innovation Center, Inc. All rights reserved.
5  * Copyright (c) 2023, Linaro Limited
6  */
7
8 #include <dt-bindings/interconnect/qcom,sm6115.h>
9 #include <linux/device.h>
10 #include <linux/interconnect-provider.h>
11 #include <linux/mod_devicetable.h>
12 #include <linux/module.h>
13 #include <linux/platform_device.h>
14 #include <linux/regmap.h>
15
16 #include "icc-rpm.h"
17
18 static const char * const snoc_intf_clocks[] = {
19         "cpu_axi",
20         "ufs_axi",
21         "usb_axi",
22         "ipa", /* Required by qxm_ipa */
23 };
24
25 static const char * const cnoc_intf_clocks[] = {
26         "usb_axi",
27 };
28
29 enum {
30         SM6115_MASTER_AMPSS_M0,
31         SM6115_MASTER_ANOC_SNOC,
32         SM6115_MASTER_BIMC_SNOC,
33         SM6115_MASTER_CAMNOC_HF,
34         SM6115_MASTER_CAMNOC_SF,
35         SM6115_MASTER_CRYPTO_CORE0,
36         SM6115_MASTER_GRAPHICS_3D,
37         SM6115_MASTER_IPA,
38         SM6115_MASTER_MDP_PORT0,
39         SM6115_MASTER_PIMEM,
40         SM6115_MASTER_QDSS_BAM,
41         SM6115_MASTER_QDSS_DAP,
42         SM6115_MASTER_QDSS_ETR,
43         SM6115_MASTER_QPIC,
44         SM6115_MASTER_QUP_0,
45         SM6115_MASTER_QUP_CORE_0,
46         SM6115_MASTER_SDCC_1,
47         SM6115_MASTER_SDCC_2,
48         SM6115_MASTER_SNOC_BIMC_NRT,
49         SM6115_MASTER_SNOC_BIMC_RT,
50         SM6115_MASTER_SNOC_BIMC,
51         SM6115_MASTER_SNOC_CFG,
52         SM6115_MASTER_SNOC_CNOC,
53         SM6115_MASTER_TCU_0,
54         SM6115_MASTER_TIC,
55         SM6115_MASTER_USB3,
56         SM6115_MASTER_VIDEO_P0,
57         SM6115_MASTER_VIDEO_PROC,
58
59         SM6115_SLAVE_AHB2PHY_USB,
60         SM6115_SLAVE_ANOC_SNOC,
61         SM6115_SLAVE_APPSS,
62         SM6115_SLAVE_APSS_THROTTLE_CFG,
63         SM6115_SLAVE_BIMC_CFG,
64         SM6115_SLAVE_BIMC_SNOC,
65         SM6115_SLAVE_BOOT_ROM,
66         SM6115_SLAVE_CAMERA_CFG,
67         SM6115_SLAVE_CAMERA_NRT_THROTTLE_CFG,
68         SM6115_SLAVE_CAMERA_RT_THROTTLE_CFG,
69         SM6115_SLAVE_CLK_CTL,
70         SM6115_SLAVE_CNOC_MSS,
71         SM6115_SLAVE_CRYPTO_0_CFG,
72         SM6115_SLAVE_DCC_CFG,
73         SM6115_SLAVE_DDR_PHY_CFG,
74         SM6115_SLAVE_DDR_SS_CFG,
75         SM6115_SLAVE_DISPLAY_CFG,
76         SM6115_SLAVE_DISPLAY_THROTTLE_CFG,
77         SM6115_SLAVE_EBI_CH0,
78         SM6115_SLAVE_GPU_CFG,
79         SM6115_SLAVE_GPU_THROTTLE_CFG,
80         SM6115_SLAVE_HWKM_CORE,
81         SM6115_SLAVE_IMEM_CFG,
82         SM6115_SLAVE_IPA_CFG,
83         SM6115_SLAVE_LPASS,
84         SM6115_SLAVE_MAPSS,
85         SM6115_SLAVE_MDSP_MPU_CFG,
86         SM6115_SLAVE_MESSAGE_RAM,
87         SM6115_SLAVE_OCIMEM,
88         SM6115_SLAVE_PDM,
89         SM6115_SLAVE_PIMEM_CFG,
90         SM6115_SLAVE_PIMEM,
91         SM6115_SLAVE_PKA_CORE,
92         SM6115_SLAVE_PMIC_ARB,
93         SM6115_SLAVE_QDSS_CFG,
94         SM6115_SLAVE_QDSS_STM,
95         SM6115_SLAVE_QM_CFG,
96         SM6115_SLAVE_QM_MPU_CFG,
97         SM6115_SLAVE_QPIC,
98         SM6115_SLAVE_QUP_0,
99         SM6115_SLAVE_QUP_CORE_0,
100         SM6115_SLAVE_RBCPR_CX_CFG,
101         SM6115_SLAVE_RBCPR_MX_CFG,
102         SM6115_SLAVE_RPM,
103         SM6115_SLAVE_SDCC_1,
104         SM6115_SLAVE_SDCC_2,
105         SM6115_SLAVE_SECURITY,
106         SM6115_SLAVE_SERVICE_CNOC,
107         SM6115_SLAVE_SERVICE_SNOC,
108         SM6115_SLAVE_SNOC_BIMC_NRT,
109         SM6115_SLAVE_SNOC_BIMC_RT,
110         SM6115_SLAVE_SNOC_BIMC,
111         SM6115_SLAVE_SNOC_CFG,
112         SM6115_SLAVE_SNOC_CNOC,
113         SM6115_SLAVE_TCSR,
114         SM6115_SLAVE_TCU,
115         SM6115_SLAVE_TLMM,
116         SM6115_SLAVE_USB3,
117         SM6115_SLAVE_VENUS_CFG,
118         SM6115_SLAVE_VENUS_THROTTLE_CFG,
119         SM6115_SLAVE_VSENSE_CTRL_CFG,
120 };
121
122 static const u16 slv_ebi_slv_bimc_snoc_links[] = {
123         SM6115_SLAVE_EBI_CH0,
124         SM6115_SLAVE_BIMC_SNOC,
125 };
126
127 static struct qcom_icc_node apps_proc = {
128         .name = "apps_proc",
129         .id = SM6115_MASTER_AMPSS_M0,
130         .channels = 1,
131         .buswidth = 16,
132         .qos.qos_port = 0,
133         .qos.qos_mode = NOC_QOS_MODE_FIXED,
134         .qos.prio_level = 0,
135         .qos.areq_prio = 0,
136         .mas_rpm_id = 0,
137         .slv_rpm_id = -1,
138         .num_links = ARRAY_SIZE(slv_ebi_slv_bimc_snoc_links),
139         .links = slv_ebi_slv_bimc_snoc_links,
140 };
141
142 static const u16 link_slv_ebi[] = {
143         SM6115_SLAVE_EBI_CH0,
144 };
145
146 static struct qcom_icc_node mas_snoc_bimc_rt = {
147         .name = "mas_snoc_bimc_rt",
148         .id = SM6115_MASTER_SNOC_BIMC_RT,
149         .channels = 1,
150         .buswidth = 16,
151         .qos.qos_port = 2,
152         .qos.qos_mode = NOC_QOS_MODE_BYPASS,
153         .qos.areq_prio = 0,
154         .qos.prio_level = 0,
155         .mas_rpm_id = -1,
156         .slv_rpm_id = -1,
157         .num_links = ARRAY_SIZE(link_slv_ebi),
158         .links = link_slv_ebi,
159 };
160
161 static struct qcom_icc_node mas_snoc_bimc_nrt = {
162         .name = "mas_snoc_bimc_nrt",
163         .id = SM6115_MASTER_SNOC_BIMC_NRT,
164         .channels = 1,
165         .buswidth = 16,
166         .qos.qos_port = 3,
167         .qos.qos_mode = NOC_QOS_MODE_BYPASS,
168         .qos.areq_prio = 0,
169         .qos.prio_level = 0,
170         .mas_rpm_id = -1,
171         .slv_rpm_id = -1,
172         .num_links = ARRAY_SIZE(link_slv_ebi),
173         .links = link_slv_ebi,
174 };
175
176 static struct qcom_icc_node mas_snoc_bimc = {
177         .name = "mas_snoc_bimc",
178         .id = SM6115_MASTER_SNOC_BIMC,
179         .channels = 1,
180         .buswidth = 16,
181         .qos.qos_port = 6,
182         .qos.qos_mode = NOC_QOS_MODE_BYPASS,
183         .qos.areq_prio = 0,
184         .qos.prio_level = 0,
185         .mas_rpm_id = 3,
186         .slv_rpm_id = -1,
187         .num_links = ARRAY_SIZE(link_slv_ebi),
188         .links = link_slv_ebi,
189 };
190
191 static struct qcom_icc_node qnm_gpu = {
192         .name = "qnm_gpu",
193         .id = SM6115_MASTER_GRAPHICS_3D,
194         .channels = 1,
195         .buswidth = 32,
196         .qos.qos_port = 1,
197         .qos.qos_mode = NOC_QOS_MODE_FIXED,
198         .qos.prio_level = 0,
199         .qos.areq_prio = 0,
200         .mas_rpm_id = -1,
201         .slv_rpm_id = -1,
202         .num_links = ARRAY_SIZE(slv_ebi_slv_bimc_snoc_links),
203         .links = slv_ebi_slv_bimc_snoc_links,
204 };
205
206 static struct qcom_icc_node tcu_0 = {
207         .name = "tcu_0",
208         .id = SM6115_MASTER_TCU_0,
209         .channels = 1,
210         .buswidth = 8,
211         .qos.qos_port = 4,
212         .qos.qos_mode = NOC_QOS_MODE_FIXED,
213         .qos.prio_level = 6,
214         .qos.areq_prio = 6,
215         .mas_rpm_id = -1,
216         .slv_rpm_id = -1,
217         .num_links = ARRAY_SIZE(slv_ebi_slv_bimc_snoc_links),
218         .links = slv_ebi_slv_bimc_snoc_links,
219 };
220
221 static const u16 qup_core_0_links[] = {
222         SM6115_SLAVE_QUP_CORE_0,
223 };
224
225 static struct qcom_icc_node qup0_core_master = {
226         .name = "qup0_core_master",
227         .id = SM6115_MASTER_QUP_CORE_0,
228         .channels = 1,
229         .buswidth = 4,
230         .mas_rpm_id = 170,
231         .slv_rpm_id = -1,
232         .num_links = ARRAY_SIZE(qup_core_0_links),
233         .links = qup_core_0_links,
234 };
235
236 static const u16 link_slv_anoc_snoc[] = {
237         SM6115_SLAVE_ANOC_SNOC,
238 };
239
240 static struct qcom_icc_node crypto_c0 = {
241         .name = "crypto_c0",
242         .id = SM6115_MASTER_CRYPTO_CORE0,
243         .channels = 1,
244         .buswidth = 8,
245         .qos.qos_port = 43,
246         .qos.qos_mode = NOC_QOS_MODE_FIXED,
247         .qos.areq_prio = 2,
248         .mas_rpm_id = 23,
249         .slv_rpm_id = -1,
250         .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
251         .links = link_slv_anoc_snoc,
252 };
253
254 static const u16 mas_snoc_cnoc_links[] = {
255         SM6115_SLAVE_AHB2PHY_USB,
256         SM6115_SLAVE_APSS_THROTTLE_CFG,
257         SM6115_SLAVE_BIMC_CFG,
258         SM6115_SLAVE_BOOT_ROM,
259         SM6115_SLAVE_CAMERA_CFG,
260         SM6115_SLAVE_CAMERA_NRT_THROTTLE_CFG,
261         SM6115_SLAVE_CAMERA_RT_THROTTLE_CFG,
262         SM6115_SLAVE_CLK_CTL,
263         SM6115_SLAVE_CNOC_MSS,
264         SM6115_SLAVE_CRYPTO_0_CFG,
265         SM6115_SLAVE_DCC_CFG,
266         SM6115_SLAVE_DDR_PHY_CFG,
267         SM6115_SLAVE_DDR_SS_CFG,
268         SM6115_SLAVE_DISPLAY_CFG,
269         SM6115_SLAVE_DISPLAY_THROTTLE_CFG,
270         SM6115_SLAVE_GPU_CFG,
271         SM6115_SLAVE_GPU_THROTTLE_CFG,
272         SM6115_SLAVE_HWKM_CORE,
273         SM6115_SLAVE_IMEM_CFG,
274         SM6115_SLAVE_IPA_CFG,
275         SM6115_SLAVE_LPASS,
276         SM6115_SLAVE_MAPSS,
277         SM6115_SLAVE_MDSP_MPU_CFG,
278         SM6115_SLAVE_MESSAGE_RAM,
279         SM6115_SLAVE_PDM,
280         SM6115_SLAVE_PIMEM_CFG,
281         SM6115_SLAVE_PKA_CORE,
282         SM6115_SLAVE_PMIC_ARB,
283         SM6115_SLAVE_QDSS_CFG,
284         SM6115_SLAVE_QM_CFG,
285         SM6115_SLAVE_QM_MPU_CFG,
286         SM6115_SLAVE_QPIC,
287         SM6115_SLAVE_QUP_0,
288         SM6115_SLAVE_RBCPR_CX_CFG,
289         SM6115_SLAVE_RBCPR_MX_CFG,
290         SM6115_SLAVE_RPM,
291         SM6115_SLAVE_SDCC_1,
292         SM6115_SLAVE_SDCC_2,
293         SM6115_SLAVE_SECURITY,
294         SM6115_SLAVE_SERVICE_CNOC,
295         SM6115_SLAVE_SNOC_CFG,
296         SM6115_SLAVE_TCSR,
297         SM6115_SLAVE_TLMM,
298         SM6115_SLAVE_USB3,
299         SM6115_SLAVE_VENUS_CFG,
300         SM6115_SLAVE_VENUS_THROTTLE_CFG,
301         SM6115_SLAVE_VSENSE_CTRL_CFG,
302 };
303
304 static struct qcom_icc_node mas_snoc_cnoc = {
305         .name = "mas_snoc_cnoc",
306         .id = SM6115_MASTER_SNOC_CNOC,
307         .channels = 1,
308         .buswidth = 8,
309         .mas_rpm_id = -1,
310         .slv_rpm_id = -1,
311         .num_links = ARRAY_SIZE(mas_snoc_cnoc_links),
312         .links = mas_snoc_cnoc_links,
313 };
314
315 static struct qcom_icc_node xm_dap = {
316         .name = "xm_dap",
317         .id = SM6115_MASTER_QDSS_DAP,
318         .channels = 1,
319         .buswidth = 8,
320         .mas_rpm_id = -1,
321         .slv_rpm_id = -1,
322         .num_links = ARRAY_SIZE(mas_snoc_cnoc_links),
323         .links = mas_snoc_cnoc_links,
324 };
325
326 static const u16 link_slv_snoc_bimc_nrt[] = {
327         SM6115_SLAVE_SNOC_BIMC_NRT,
328 };
329
330 static struct qcom_icc_node qnm_camera_nrt = {
331         .name = "qnm_camera_nrt",
332         .id = SM6115_MASTER_CAMNOC_SF,
333         .channels = 1,
334         .buswidth = 32,
335         .qos.qos_port = 25,
336         .qos.qos_mode = NOC_QOS_MODE_FIXED,
337         .qos.areq_prio = 3,
338         .mas_rpm_id = -1,
339         .slv_rpm_id = -1,
340         .num_links = ARRAY_SIZE(link_slv_snoc_bimc_nrt),
341         .links = link_slv_snoc_bimc_nrt,
342 };
343
344 static struct qcom_icc_node qxm_venus0 = {
345         .name = "qxm_venus0",
346         .id = SM6115_MASTER_VIDEO_P0,
347         .channels = 1,
348         .buswidth = 16,
349         .qos.qos_port = 30,
350         .qos.qos_mode = NOC_QOS_MODE_FIXED,
351         .qos.areq_prio = 3,
352         .qos.urg_fwd_en = true,
353         .mas_rpm_id = -1,
354         .slv_rpm_id = -1,
355         .num_links = ARRAY_SIZE(link_slv_snoc_bimc_nrt),
356         .links = link_slv_snoc_bimc_nrt,
357 };
358
359 static struct qcom_icc_node qxm_venus_cpu = {
360         .name = "qxm_venus_cpu",
361         .id = SM6115_MASTER_VIDEO_PROC,
362         .channels = 1,
363         .buswidth = 8,
364         .qos.qos_port = 34,
365         .qos.qos_mode = NOC_QOS_MODE_FIXED,
366         .qos.areq_prio = 4,
367         .mas_rpm_id = -1,
368         .slv_rpm_id = -1,
369         .num_links = ARRAY_SIZE(link_slv_snoc_bimc_nrt),
370         .links = link_slv_snoc_bimc_nrt,
371 };
372
373 static const u16 link_slv_snoc_bimc_rt[] = {
374         SM6115_SLAVE_SNOC_BIMC_RT,
375 };
376
377 static struct qcom_icc_node qnm_camera_rt = {
378         .name = "qnm_camera_rt",
379         .id = SM6115_MASTER_CAMNOC_HF,
380         .channels = 1,
381         .buswidth = 32,
382         .qos.qos_port = 31,
383         .qos.qos_mode = NOC_QOS_MODE_FIXED,
384         .qos.areq_prio = 3,
385         .qos.urg_fwd_en = true,
386         .mas_rpm_id = -1,
387         .slv_rpm_id = -1,
388         .num_links = ARRAY_SIZE(link_slv_snoc_bimc_rt),
389         .links = link_slv_snoc_bimc_rt,
390 };
391
392 static struct qcom_icc_node qxm_mdp0 = {
393         .name = "qxm_mdp0",
394         .id = SM6115_MASTER_MDP_PORT0,
395         .channels = 1,
396         .buswidth = 16,
397         .qos.qos_port = 26,
398         .qos.qos_mode = NOC_QOS_MODE_FIXED,
399         .qos.areq_prio = 3,
400         .qos.urg_fwd_en = true,
401         .mas_rpm_id = -1,
402         .slv_rpm_id = -1,
403         .num_links = ARRAY_SIZE(link_slv_snoc_bimc_rt),
404         .links = link_slv_snoc_bimc_rt,
405 };
406
407 static const u16 slv_service_snoc_links[] = {
408         SM6115_SLAVE_SERVICE_SNOC,
409 };
410
411 static struct qcom_icc_node qhm_snoc_cfg = {
412         .name = "qhm_snoc_cfg",
413         .id = SM6115_MASTER_SNOC_CFG,
414         .channels = 1,
415         .buswidth = 4,
416         .mas_rpm_id = -1,
417         .slv_rpm_id = -1,
418         .num_links = ARRAY_SIZE(slv_service_snoc_links),
419         .links = slv_service_snoc_links,
420 };
421
422 static const u16 mas_tic_links[] = {
423         SM6115_SLAVE_APPSS,
424         SM6115_SLAVE_OCIMEM,
425         SM6115_SLAVE_PIMEM,
426         SM6115_SLAVE_QDSS_STM,
427         SM6115_SLAVE_TCU,
428         SM6115_SLAVE_SNOC_BIMC,
429         SM6115_SLAVE_SNOC_CNOC,
430 };
431
432 static struct qcom_icc_node qhm_tic = {
433         .name = "qhm_tic",
434         .id = SM6115_MASTER_TIC,
435         .channels = 1,
436         .buswidth = 4,
437         .qos.qos_port = 29,
438         .qos.qos_mode = NOC_QOS_MODE_FIXED,
439         .qos.areq_prio = 2,
440         .mas_rpm_id = -1,
441         .slv_rpm_id = -1,
442         .num_links = ARRAY_SIZE(mas_tic_links),
443         .links = mas_tic_links,
444 };
445
446 static struct qcom_icc_node mas_anoc_snoc = {
447         .name = "mas_anoc_snoc",
448         .id = SM6115_MASTER_ANOC_SNOC,
449         .channels = 1,
450         .buswidth = 16,
451         .mas_rpm_id = -1,
452         .slv_rpm_id = -1,
453         .num_links = ARRAY_SIZE(mas_tic_links),
454         .links = mas_tic_links,
455 };
456
457 static const u16 mas_bimc_snoc_links[] = {
458         SM6115_SLAVE_APPSS,
459         SM6115_SLAVE_SNOC_CNOC,
460         SM6115_SLAVE_OCIMEM,
461         SM6115_SLAVE_PIMEM,
462         SM6115_SLAVE_QDSS_STM,
463         SM6115_SLAVE_TCU,
464 };
465
466 static struct qcom_icc_node mas_bimc_snoc = {
467         .name = "mas_bimc_snoc",
468         .id = SM6115_MASTER_BIMC_SNOC,
469         .channels = 1,
470         .buswidth = 8,
471         .mas_rpm_id = 21,
472         .slv_rpm_id = -1,
473         .num_links = ARRAY_SIZE(mas_bimc_snoc_links),
474         .links = mas_bimc_snoc_links,
475 };
476
477 static const u16 mas_pimem_links[] = {
478         SM6115_SLAVE_OCIMEM,
479         SM6115_SLAVE_SNOC_BIMC,
480 };
481
482 static struct qcom_icc_node qxm_pimem = {
483         .name = "qxm_pimem",
484         .id = SM6115_MASTER_PIMEM,
485         .channels = 1,
486         .buswidth = 8,
487         .qos.qos_port = 41,
488         .qos.qos_mode = NOC_QOS_MODE_FIXED,
489         .qos.areq_prio = 2,
490         .mas_rpm_id = -1,
491         .slv_rpm_id = -1,
492         .num_links = ARRAY_SIZE(mas_pimem_links),
493         .links = mas_pimem_links,
494 };
495
496 static struct qcom_icc_node qhm_qdss_bam = {
497         .name = "qhm_qdss_bam",
498         .id = SM6115_MASTER_QDSS_BAM,
499         .channels = 1,
500         .buswidth = 4,
501         .qos.qos_port = 23,
502         .qos.qos_mode = NOC_QOS_MODE_FIXED,
503         .qos.areq_prio = 2,
504         .mas_rpm_id = -1,
505         .slv_rpm_id = -1,
506         .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
507         .links = link_slv_anoc_snoc,
508 };
509
510 static struct qcom_icc_node qhm_qpic = {
511         .name = "qhm_qpic",
512         .id = SM6115_MASTER_QPIC,
513         .channels = 1,
514         .buswidth = 4,
515         .mas_rpm_id = -1,
516         .slv_rpm_id = -1,
517         .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
518         .links = link_slv_anoc_snoc,
519 };
520
521 static struct qcom_icc_node qhm_qup0 = {
522         .name = "qhm_qup0",
523         .id = SM6115_MASTER_QUP_0,
524         .channels = 1,
525         .buswidth = 4,
526         .qos.qos_port = 21,
527         .qos.qos_mode = NOC_QOS_MODE_FIXED,
528         .qos.areq_prio = 2,
529         .mas_rpm_id = 166,
530         .slv_rpm_id = -1,
531         .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
532         .links = link_slv_anoc_snoc,
533 };
534
535 static struct qcom_icc_node qxm_ipa = {
536         .name = "qxm_ipa",
537         .id = SM6115_MASTER_IPA,
538         .channels = 1,
539         .buswidth = 8,
540         .qos.qos_port = 24,
541         .qos.qos_mode = NOC_QOS_MODE_FIXED,
542         .qos.areq_prio = 2,
543         .mas_rpm_id = 59,
544         .slv_rpm_id = -1,
545         .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
546         .links = link_slv_anoc_snoc,
547 };
548
549 static struct qcom_icc_node xm_qdss_etr = {
550         .name = "xm_qdss_etr",
551         .id = SM6115_MASTER_QDSS_ETR,
552         .channels = 1,
553         .buswidth = 8,
554         .qos.qos_port = 33,
555         .qos.qos_mode = NOC_QOS_MODE_FIXED,
556         .qos.areq_prio = 2,
557         .mas_rpm_id = -1,
558         .slv_rpm_id = -1,
559         .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
560         .links = link_slv_anoc_snoc,
561 };
562
563 static struct qcom_icc_node xm_sdc1 = {
564         .name = "xm_sdc1",
565         .id = SM6115_MASTER_SDCC_1,
566         .channels = 1,
567         .buswidth = 8,
568         .qos.qos_port = 38,
569         .qos.qos_mode = NOC_QOS_MODE_FIXED,
570         .qos.areq_prio = 2,
571         .mas_rpm_id = 33,
572         .slv_rpm_id = -1,
573         .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
574         .links = link_slv_anoc_snoc,
575 };
576
577 static struct qcom_icc_node xm_sdc2 = {
578         .name = "xm_sdc2",
579         .id = SM6115_MASTER_SDCC_2,
580         .channels = 1,
581         .buswidth = 8,
582         .qos.qos_port = 44,
583         .qos.qos_mode = NOC_QOS_MODE_FIXED,
584         .qos.areq_prio = 2,
585         .mas_rpm_id = 35,
586         .slv_rpm_id = -1,
587         .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
588         .links = link_slv_anoc_snoc,
589 };
590
591 static struct qcom_icc_node xm_usb3_0 = {
592         .name = "xm_usb3_0",
593         .id = SM6115_MASTER_USB3,
594         .channels = 1,
595         .buswidth = 8,
596         .qos.qos_port = 45,
597         .qos.qos_mode = NOC_QOS_MODE_FIXED,
598         .qos.areq_prio = 2,
599         .mas_rpm_id = -1,
600         .slv_rpm_id = -1,
601         .num_links = ARRAY_SIZE(link_slv_anoc_snoc),
602         .links = link_slv_anoc_snoc,
603 };
604
605 static struct qcom_icc_node ebi = {
606         .name = "ebi",
607         .id = SM6115_SLAVE_EBI_CH0,
608         .channels = 2,
609         .buswidth = 4,
610         .mas_rpm_id = -1,
611         .slv_rpm_id = 0,
612 };
613
614 static const u16 slv_bimc_snoc_links[] = {
615         SM6115_MASTER_BIMC_SNOC,
616 };
617
618 static struct qcom_icc_node slv_bimc_snoc = {
619         .name = "slv_bimc_snoc",
620         .id = SM6115_SLAVE_BIMC_SNOC,
621         .channels = 1,
622         .buswidth = 16,
623         .mas_rpm_id = -1,
624         .slv_rpm_id = 2,
625         .num_links = ARRAY_SIZE(slv_bimc_snoc_links),
626         .links = slv_bimc_snoc_links,
627 };
628
629 static struct qcom_icc_node qup0_core_slave = {
630         .name = "qup0_core_slave",
631         .id = SM6115_SLAVE_QUP_CORE_0,
632         .channels = 1,
633         .buswidth = 4,
634         .mas_rpm_id = -1,
635         .slv_rpm_id = -1,
636 };
637
638 static struct qcom_icc_node qhs_ahb2phy_usb = {
639         .name = "qhs_ahb2phy_usb",
640         .id = SM6115_SLAVE_AHB2PHY_USB,
641         .channels = 1,
642         .buswidth = 4,
643         .mas_rpm_id = -1,
644         .slv_rpm_id = -1,
645 };
646
647 static struct qcom_icc_node qhs_apss_throttle_cfg = {
648         .name = "qhs_apss_throttle_cfg",
649         .id = SM6115_SLAVE_APSS_THROTTLE_CFG,
650         .channels = 1,
651         .buswidth = 4,
652         .mas_rpm_id = -1,
653         .slv_rpm_id = -1,
654 };
655
656 static struct qcom_icc_node qhs_bimc_cfg = {
657         .name = "qhs_bimc_cfg",
658         .id = SM6115_SLAVE_BIMC_CFG,
659         .channels = 1,
660         .buswidth = 4,
661         .mas_rpm_id = -1,
662         .slv_rpm_id = -1,
663 };
664
665 static struct qcom_icc_node qhs_boot_rom = {
666         .name = "qhs_boot_rom",
667         .id = SM6115_SLAVE_BOOT_ROM,
668         .channels = 1,
669         .buswidth = 4,
670         .mas_rpm_id = -1,
671         .slv_rpm_id = -1,
672 };
673
674 static struct qcom_icc_node qhs_camera_nrt_throttle_cfg = {
675         .name = "qhs_camera_nrt_throttle_cfg",
676         .id = SM6115_SLAVE_CAMERA_NRT_THROTTLE_CFG,
677         .channels = 1,
678         .buswidth = 4,
679         .mas_rpm_id = -1,
680         .slv_rpm_id = -1,
681 };
682
683 static struct qcom_icc_node qhs_camera_rt_throttle_cfg = {
684         .name = "qhs_camera_rt_throttle_cfg",
685         .id = SM6115_SLAVE_CAMERA_RT_THROTTLE_CFG,
686         .channels = 1,
687         .buswidth = 4,
688         .mas_rpm_id = -1,
689         .slv_rpm_id = -1,
690 };
691
692 static struct qcom_icc_node qhs_camera_ss_cfg = {
693         .name = "qhs_camera_ss_cfg",
694         .id = SM6115_SLAVE_CAMERA_CFG,
695         .channels = 1,
696         .buswidth = 4,
697         .mas_rpm_id = -1,
698         .slv_rpm_id = -1,
699 };
700
701 static struct qcom_icc_node qhs_clk_ctl = {
702         .name = "qhs_clk_ctl",
703         .id = SM6115_SLAVE_CLK_CTL,
704         .channels = 1,
705         .buswidth = 4,
706         .mas_rpm_id = -1,
707         .slv_rpm_id = -1,
708 };
709
710 static struct qcom_icc_node qhs_cpr_cx = {
711         .name = "qhs_cpr_cx",
712         .id = SM6115_SLAVE_RBCPR_CX_CFG,
713         .channels = 1,
714         .buswidth = 4,
715         .mas_rpm_id = -1,
716         .slv_rpm_id = -1,
717 };
718
719 static struct qcom_icc_node qhs_cpr_mx = {
720         .name = "qhs_cpr_mx",
721         .id = SM6115_SLAVE_RBCPR_MX_CFG,
722         .channels = 1,
723         .buswidth = 4,
724         .mas_rpm_id = -1,
725         .slv_rpm_id = -1,
726 };
727
728 static struct qcom_icc_node qhs_crypto0_cfg = {
729         .name = "qhs_crypto0_cfg",
730         .id = SM6115_SLAVE_CRYPTO_0_CFG,
731         .channels = 1,
732         .buswidth = 4,
733         .mas_rpm_id = -1,
734         .slv_rpm_id = -1,
735 };
736
737 static struct qcom_icc_node qhs_dcc_cfg = {
738         .name = "qhs_dcc_cfg",
739         .id = SM6115_SLAVE_DCC_CFG,
740         .channels = 1,
741         .buswidth = 4,
742         .mas_rpm_id = -1,
743         .slv_rpm_id = -1,
744 };
745
746 static struct qcom_icc_node qhs_ddr_phy_cfg = {
747         .name = "qhs_ddr_phy_cfg",
748         .id = SM6115_SLAVE_DDR_PHY_CFG,
749         .channels = 1,
750         .buswidth = 4,
751         .mas_rpm_id = -1,
752         .slv_rpm_id = -1,
753 };
754
755 static struct qcom_icc_node qhs_ddr_ss_cfg = {
756         .name = "qhs_ddr_ss_cfg",
757         .id = SM6115_SLAVE_DDR_SS_CFG,
758         .channels = 1,
759         .buswidth = 4,
760         .mas_rpm_id = -1,
761         .slv_rpm_id = -1,
762 };
763
764 static struct qcom_icc_node qhs_disp_ss_cfg = {
765         .name = "qhs_disp_ss_cfg",
766         .id = SM6115_SLAVE_DISPLAY_CFG,
767         .channels = 1,
768         .buswidth = 4,
769         .mas_rpm_id = -1,
770         .slv_rpm_id = -1,
771 };
772
773 static struct qcom_icc_node qhs_display_throttle_cfg = {
774         .name = "qhs_display_throttle_cfg",
775         .id = SM6115_SLAVE_DISPLAY_THROTTLE_CFG,
776         .channels = 1,
777         .buswidth = 4,
778         .mas_rpm_id = -1,
779         .slv_rpm_id = -1,
780 };
781
782 static struct qcom_icc_node qhs_gpu_cfg = {
783         .name = "qhs_gpu_cfg",
784         .id = SM6115_SLAVE_GPU_CFG,
785         .channels = 1,
786         .buswidth = 8,
787         .mas_rpm_id = -1,
788         .slv_rpm_id = -1,
789 };
790
791 static struct qcom_icc_node qhs_gpu_throttle_cfg = {
792         .name = "qhs_gpu_throttle_cfg",
793         .id = SM6115_SLAVE_GPU_THROTTLE_CFG,
794         .channels = 1,
795         .buswidth = 4,
796         .mas_rpm_id = -1,
797         .slv_rpm_id = -1,
798 };
799
800 static struct qcom_icc_node qhs_hwkm = {
801         .name = "qhs_hwkm",
802         .id = SM6115_SLAVE_HWKM_CORE,
803         .channels = 1,
804         .buswidth = 4,
805         .mas_rpm_id = -1,
806         .slv_rpm_id = -1,
807 };
808
809 static struct qcom_icc_node qhs_imem_cfg = {
810         .name = "qhs_imem_cfg",
811         .id = SM6115_SLAVE_IMEM_CFG,
812         .channels = 1,
813         .buswidth = 4,
814         .mas_rpm_id = -1,
815         .slv_rpm_id = -1,
816 };
817
818 static struct qcom_icc_node qhs_ipa_cfg = {
819         .name = "qhs_ipa_cfg",
820         .id = SM6115_SLAVE_IPA_CFG,
821         .channels = 1,
822         .buswidth = 4,
823         .mas_rpm_id = -1,
824         .slv_rpm_id = -1,
825 };
826
827 static struct qcom_icc_node qhs_lpass = {
828         .name = "qhs_lpass",
829         .id = SM6115_SLAVE_LPASS,
830         .channels = 1,
831         .buswidth = 4,
832         .mas_rpm_id = -1,
833         .slv_rpm_id = -1,
834 };
835
836 static struct qcom_icc_node qhs_mapss = {
837         .name = "qhs_mapss",
838         .id = SM6115_SLAVE_MAPSS,
839         .channels = 1,
840         .buswidth = 4,
841         .mas_rpm_id = -1,
842         .slv_rpm_id = -1,
843 };
844
845 static struct qcom_icc_node qhs_mdsp_mpu_cfg = {
846         .name = "qhs_mdsp_mpu_cfg",
847         .id = SM6115_SLAVE_MDSP_MPU_CFG,
848         .channels = 1,
849         .buswidth = 4,
850         .mas_rpm_id = -1,
851         .slv_rpm_id = -1,
852 };
853
854 static struct qcom_icc_node qhs_mesg_ram = {
855         .name = "qhs_mesg_ram",
856         .id = SM6115_SLAVE_MESSAGE_RAM,
857         .channels = 1,
858         .buswidth = 4,
859         .mas_rpm_id = -1,
860         .slv_rpm_id = -1,
861 };
862
863 static struct qcom_icc_node qhs_mss = {
864         .name = "qhs_mss",
865         .id = SM6115_SLAVE_CNOC_MSS,
866         .channels = 1,
867         .buswidth = 4,
868         .mas_rpm_id = -1,
869         .slv_rpm_id = -1,
870 };
871
872 static struct qcom_icc_node qhs_pdm = {
873         .name = "qhs_pdm",
874         .id = SM6115_SLAVE_PDM,
875         .channels = 1,
876         .buswidth = 4,
877         .mas_rpm_id = -1,
878         .slv_rpm_id = -1,
879 };
880
881 static struct qcom_icc_node qhs_pimem_cfg = {
882         .name = "qhs_pimem_cfg",
883         .id = SM6115_SLAVE_PIMEM_CFG,
884         .channels = 1,
885         .buswidth = 4,
886         .mas_rpm_id = -1,
887         .slv_rpm_id = -1,
888 };
889
890 static struct qcom_icc_node qhs_pka_wrapper = {
891         .name = "qhs_pka_wrapper",
892         .id = SM6115_SLAVE_PKA_CORE,
893         .channels = 1,
894         .buswidth = 4,
895         .mas_rpm_id = -1,
896         .slv_rpm_id = -1,
897 };
898
899 static struct qcom_icc_node qhs_pmic_arb = {
900         .name = "qhs_pmic_arb",
901         .id = SM6115_SLAVE_PMIC_ARB,
902         .channels = 1,
903         .buswidth = 4,
904         .mas_rpm_id = -1,
905         .slv_rpm_id = -1,
906 };
907
908 static struct qcom_icc_node qhs_qdss_cfg = {
909         .name = "qhs_qdss_cfg",
910         .id = SM6115_SLAVE_QDSS_CFG,
911         .channels = 1,
912         .buswidth = 4,
913         .mas_rpm_id = -1,
914         .slv_rpm_id = -1,
915 };
916
917 static struct qcom_icc_node qhs_qm_cfg = {
918         .name = "qhs_qm_cfg",
919         .id = SM6115_SLAVE_QM_CFG,
920         .channels = 1,
921         .buswidth = 4,
922         .mas_rpm_id = -1,
923         .slv_rpm_id = -1,
924 };
925
926 static struct qcom_icc_node qhs_qm_mpu_cfg = {
927         .name = "qhs_qm_mpu_cfg",
928         .id = SM6115_SLAVE_QM_MPU_CFG,
929         .channels = 1,
930         .buswidth = 4,
931         .mas_rpm_id = -1,
932         .slv_rpm_id = -1,
933 };
934
935 static struct qcom_icc_node qhs_qpic = {
936         .name = "qhs_qpic",
937         .id = SM6115_SLAVE_QPIC,
938         .channels = 1,
939         .buswidth = 4,
940         .mas_rpm_id = -1,
941         .slv_rpm_id = -1,
942 };
943
944 static struct qcom_icc_node qhs_qup0 = {
945         .name = "qhs_qup0",
946         .id = SM6115_SLAVE_QUP_0,
947         .channels = 1,
948         .buswidth = 4,
949         .mas_rpm_id = -1,
950         .slv_rpm_id = -1,
951 };
952
953 static struct qcom_icc_node qhs_rpm = {
954         .name = "qhs_rpm",
955         .id = SM6115_SLAVE_RPM,
956         .channels = 1,
957         .buswidth = 4,
958         .mas_rpm_id = -1,
959         .slv_rpm_id = -1,
960 };
961
962 static struct qcom_icc_node qhs_sdc1 = {
963         .name = "qhs_sdc1",
964         .id = SM6115_SLAVE_SDCC_1,
965         .channels = 1,
966         .buswidth = 4,
967         .mas_rpm_id = -1,
968         .slv_rpm_id = -1,
969 };
970
971 static struct qcom_icc_node qhs_sdc2 = {
972         .name = "qhs_sdc2",
973         .id = SM6115_SLAVE_SDCC_2,
974         .channels = 1,
975         .buswidth = 4,
976         .mas_rpm_id = -1,
977         .slv_rpm_id = -1,
978 };
979
980 static struct qcom_icc_node qhs_security = {
981         .name = "qhs_security",
982         .id = SM6115_SLAVE_SECURITY,
983         .channels = 1,
984         .buswidth = 4,
985         .mas_rpm_id = -1,
986         .slv_rpm_id = -1,
987 };
988
989 static const u16 slv_snoc_cfg_links[] = {
990         SM6115_MASTER_SNOC_CFG,
991 };
992
993 static struct qcom_icc_node qhs_snoc_cfg = {
994         .name = "qhs_snoc_cfg",
995         .id = SM6115_SLAVE_SNOC_CFG,
996         .channels = 1,
997         .buswidth = 4,
998         .mas_rpm_id = -1,
999         .slv_rpm_id = -1,
1000         .num_links = ARRAY_SIZE(slv_snoc_cfg_links),
1001         .links = slv_snoc_cfg_links,
1002 };
1003
1004 static struct qcom_icc_node qhs_tcsr = {
1005         .name = "qhs_tcsr",
1006         .id = SM6115_SLAVE_TCSR,
1007         .channels = 1,
1008         .buswidth = 4,
1009         .mas_rpm_id = -1,
1010         .slv_rpm_id = -1,
1011 };
1012
1013 static struct qcom_icc_node qhs_tlmm = {
1014         .name = "qhs_tlmm",
1015         .id = SM6115_SLAVE_TLMM,
1016         .channels = 1,
1017         .buswidth = 4,
1018         .mas_rpm_id = -1,
1019         .slv_rpm_id = -1,
1020 };
1021
1022 static struct qcom_icc_node qhs_usb3 = {
1023         .name = "qhs_usb3",
1024         .id = SM6115_SLAVE_USB3,
1025         .channels = 1,
1026         .buswidth = 4,
1027         .mas_rpm_id = -1,
1028         .slv_rpm_id = -1,
1029 };
1030
1031 static struct qcom_icc_node qhs_venus_cfg = {
1032         .name = "qhs_venus_cfg",
1033         .id = SM6115_SLAVE_VENUS_CFG,
1034         .channels = 1,
1035         .buswidth = 4,
1036         .mas_rpm_id = -1,
1037         .slv_rpm_id = -1,
1038 };
1039
1040 static struct qcom_icc_node qhs_venus_throttle_cfg = {
1041         .name = "qhs_venus_throttle_cfg",
1042         .id = SM6115_SLAVE_VENUS_THROTTLE_CFG,
1043         .channels = 1,
1044         .buswidth = 4,
1045         .mas_rpm_id = -1,
1046         .slv_rpm_id = -1,
1047 };
1048
1049 static struct qcom_icc_node qhs_vsense_ctrl_cfg = {
1050         .name = "qhs_vsense_ctrl_cfg",
1051         .id = SM6115_SLAVE_VSENSE_CTRL_CFG,
1052         .channels = 1,
1053         .buswidth = 4,
1054         .mas_rpm_id = -1,
1055         .slv_rpm_id = -1,
1056 };
1057
1058 static struct qcom_icc_node srvc_cnoc = {
1059         .name = "srvc_cnoc",
1060         .id = SM6115_SLAVE_SERVICE_CNOC,
1061         .channels = 1,
1062         .buswidth = 4,
1063         .mas_rpm_id = -1,
1064         .slv_rpm_id = -1,
1065 };
1066
1067 static const u16 slv_snoc_bimc_nrt_links[] = {
1068         SM6115_MASTER_SNOC_BIMC_NRT,
1069 };
1070
1071 static struct qcom_icc_node slv_snoc_bimc_nrt = {
1072         .name = "slv_snoc_bimc_nrt",
1073         .id = SM6115_SLAVE_SNOC_BIMC_NRT,
1074         .channels = 1,
1075         .buswidth = 16,
1076         .mas_rpm_id = -1,
1077         .slv_rpm_id = -1,
1078         .num_links = ARRAY_SIZE(slv_snoc_bimc_nrt_links),
1079         .links = slv_snoc_bimc_nrt_links,
1080 };
1081
1082 static const u16 slv_snoc_bimc_rt_links[] = {
1083         SM6115_MASTER_SNOC_BIMC_RT,
1084 };
1085
1086 static struct qcom_icc_node slv_snoc_bimc_rt = {
1087         .name = "slv_snoc_bimc_rt",
1088         .id = SM6115_SLAVE_SNOC_BIMC_RT,
1089         .channels = 1,
1090         .buswidth = 16,
1091         .mas_rpm_id = -1,
1092         .slv_rpm_id = -1,
1093         .num_links = ARRAY_SIZE(slv_snoc_bimc_rt_links),
1094         .links = slv_snoc_bimc_rt_links,
1095 };
1096
1097 static struct qcom_icc_node qhs_apss = {
1098         .name = "qhs_apss",
1099         .id = SM6115_SLAVE_APPSS,
1100         .channels = 1,
1101         .buswidth = 8,
1102         .mas_rpm_id = -1,
1103         .slv_rpm_id = -1,
1104 };
1105
1106 static const u16 slv_snoc_cnoc_links[] = {
1107         SM6115_MASTER_SNOC_CNOC
1108 };
1109
1110 static struct qcom_icc_node slv_snoc_cnoc = {
1111         .name = "slv_snoc_cnoc",
1112         .id = SM6115_SLAVE_SNOC_CNOC,
1113         .channels = 1,
1114         .buswidth = 8,
1115         .mas_rpm_id = -1,
1116         .slv_rpm_id = 25,
1117         .num_links = ARRAY_SIZE(slv_snoc_cnoc_links),
1118         .links = slv_snoc_cnoc_links,
1119 };
1120
1121 static struct qcom_icc_node qxs_imem = {
1122         .name = "qxs_imem",
1123         .id = SM6115_SLAVE_OCIMEM,
1124         .channels = 1,
1125         .buswidth = 8,
1126         .mas_rpm_id = -1,
1127         .slv_rpm_id = 26,
1128 };
1129
1130 static struct qcom_icc_node qxs_pimem = {
1131         .name = "qxs_pimem",
1132         .id = SM6115_SLAVE_PIMEM,
1133         .channels = 1,
1134         .buswidth = 8,
1135         .mas_rpm_id = -1,
1136         .slv_rpm_id = -1,
1137 };
1138
1139 static const u16 slv_snoc_bimc_links[] = {
1140         SM6115_MASTER_SNOC_BIMC,
1141 };
1142
1143 static struct qcom_icc_node slv_snoc_bimc = {
1144         .name = "slv_snoc_bimc",
1145         .id = SM6115_SLAVE_SNOC_BIMC,
1146         .channels = 1,
1147         .buswidth = 16,
1148         .mas_rpm_id = -1,
1149         .slv_rpm_id = 24,
1150         .num_links = ARRAY_SIZE(slv_snoc_bimc_links),
1151         .links = slv_snoc_bimc_links,
1152 };
1153
1154 static struct qcom_icc_node srvc_snoc = {
1155         .name = "srvc_snoc",
1156         .id = SM6115_SLAVE_SERVICE_SNOC,
1157         .channels = 1,
1158         .buswidth = 4,
1159         .mas_rpm_id = -1,
1160         .slv_rpm_id = -1,
1161 };
1162
1163 static struct qcom_icc_node xs_qdss_stm = {
1164         .name = "xs_qdss_stm",
1165         .id = SM6115_SLAVE_QDSS_STM,
1166         .channels = 1,
1167         .buswidth = 4,
1168         .mas_rpm_id = -1,
1169         .slv_rpm_id = 30,
1170 };
1171
1172 static struct qcom_icc_node xs_sys_tcu_cfg = {
1173         .name = "xs_sys_tcu_cfg",
1174         .id = SM6115_SLAVE_TCU,
1175         .channels = 1,
1176         .buswidth = 8,
1177         .mas_rpm_id = -1,
1178         .slv_rpm_id = -1,
1179 };
1180
1181 static const u16 slv_anoc_snoc_links[] = {
1182         SM6115_MASTER_ANOC_SNOC,
1183 };
1184
1185 static struct qcom_icc_node slv_anoc_snoc = {
1186         .name = "slv_anoc_snoc",
1187         .id = SM6115_SLAVE_ANOC_SNOC,
1188         .channels = 1,
1189         .buswidth = 16,
1190         .mas_rpm_id = -1,
1191         .slv_rpm_id = -1,
1192         .num_links = ARRAY_SIZE(slv_anoc_snoc_links),
1193         .links = slv_anoc_snoc_links,
1194 };
1195
1196 static struct qcom_icc_node * const bimc_nodes[] = {
1197         [MASTER_AMPSS_M0] = &apps_proc,
1198         [MASTER_SNOC_BIMC_RT] = &mas_snoc_bimc_rt,
1199         [MASTER_SNOC_BIMC_NRT] = &mas_snoc_bimc_nrt,
1200         [SNOC_BIMC_MAS] = &mas_snoc_bimc,
1201         [MASTER_GRAPHICS_3D] = &qnm_gpu,
1202         [MASTER_TCU_0] = &tcu_0,
1203         [SLAVE_EBI_CH0] = &ebi,
1204         [BIMC_SNOC_SLV] = &slv_bimc_snoc,
1205 };
1206
1207 static const struct regmap_config bimc_regmap_config = {
1208         .reg_bits       = 32,
1209         .reg_stride     = 4,
1210         .val_bits       = 32,
1211         .max_register   = 0x80000,
1212         .fast_io        = true,
1213 };
1214
1215 static const struct qcom_icc_desc sm6115_bimc = {
1216         .type = QCOM_ICC_BIMC,
1217         .nodes = bimc_nodes,
1218         .num_nodes = ARRAY_SIZE(bimc_nodes),
1219         .regmap_cfg = &bimc_regmap_config,
1220         .bus_clk_desc = &bimc_clk,
1221         .keep_alive = true,
1222         .qos_offset = 0x8000,
1223         .ab_coeff = 153,
1224 };
1225
1226 static struct qcom_icc_node * const config_noc_nodes[] = {
1227         [SNOC_CNOC_MAS] = &mas_snoc_cnoc,
1228         [MASTER_QDSS_DAP] = &xm_dap,
1229         [SLAVE_AHB2PHY_USB] = &qhs_ahb2phy_usb,
1230         [SLAVE_APSS_THROTTLE_CFG] = &qhs_apss_throttle_cfg,
1231         [SLAVE_BIMC_CFG] = &qhs_bimc_cfg,
1232         [SLAVE_BOOT_ROM] = &qhs_boot_rom,
1233         [SLAVE_CAMERA_NRT_THROTTLE_CFG] = &qhs_camera_nrt_throttle_cfg,
1234         [SLAVE_CAMERA_RT_THROTTLE_CFG] = &qhs_camera_rt_throttle_cfg,
1235         [SLAVE_CAMERA_CFG] = &qhs_camera_ss_cfg,
1236         [SLAVE_CLK_CTL] = &qhs_clk_ctl,
1237         [SLAVE_RBCPR_CX_CFG] = &qhs_cpr_cx,
1238         [SLAVE_RBCPR_MX_CFG] = &qhs_cpr_mx,
1239         [SLAVE_CRYPTO_0_CFG] = &qhs_crypto0_cfg,
1240         [SLAVE_DCC_CFG] = &qhs_dcc_cfg,
1241         [SLAVE_DDR_PHY_CFG] = &qhs_ddr_phy_cfg,
1242         [SLAVE_DDR_SS_CFG] = &qhs_ddr_ss_cfg,
1243         [SLAVE_DISPLAY_CFG] = &qhs_disp_ss_cfg,
1244         [SLAVE_DISPLAY_THROTTLE_CFG] = &qhs_display_throttle_cfg,
1245         [SLAVE_GPU_CFG] = &qhs_gpu_cfg,
1246         [SLAVE_GPU_THROTTLE_CFG] = &qhs_gpu_throttle_cfg,
1247         [SLAVE_HWKM_CORE] = &qhs_hwkm,
1248         [SLAVE_IMEM_CFG] = &qhs_imem_cfg,
1249         [SLAVE_IPA_CFG] = &qhs_ipa_cfg,
1250         [SLAVE_LPASS] = &qhs_lpass,
1251         [SLAVE_MAPSS] = &qhs_mapss,
1252         [SLAVE_MDSP_MPU_CFG] = &qhs_mdsp_mpu_cfg,
1253         [SLAVE_MESSAGE_RAM] = &qhs_mesg_ram,
1254         [SLAVE_CNOC_MSS] = &qhs_mss,
1255         [SLAVE_PDM] = &qhs_pdm,
1256         [SLAVE_PIMEM_CFG] = &qhs_pimem_cfg,
1257         [SLAVE_PKA_CORE] = &qhs_pka_wrapper,
1258         [SLAVE_PMIC_ARB] = &qhs_pmic_arb,
1259         [SLAVE_QDSS_CFG] = &qhs_qdss_cfg,
1260         [SLAVE_QM_CFG] = &qhs_qm_cfg,
1261         [SLAVE_QM_MPU_CFG] = &qhs_qm_mpu_cfg,
1262         [SLAVE_QPIC] = &qhs_qpic,
1263         [SLAVE_QUP_0] = &qhs_qup0,
1264         [SLAVE_RPM] = &qhs_rpm,
1265         [SLAVE_SDCC_1] = &qhs_sdc1,
1266         [SLAVE_SDCC_2] = &qhs_sdc2,
1267         [SLAVE_SECURITY] = &qhs_security,
1268         [SLAVE_SNOC_CFG] = &qhs_snoc_cfg,
1269         [SLAVE_TCSR] = &qhs_tcsr,
1270         [SLAVE_TLMM] = &qhs_tlmm,
1271         [SLAVE_USB3] = &qhs_usb3,
1272         [SLAVE_VENUS_CFG] = &qhs_venus_cfg,
1273         [SLAVE_VENUS_THROTTLE_CFG] = &qhs_venus_throttle_cfg,
1274         [SLAVE_VSENSE_CTRL_CFG] = &qhs_vsense_ctrl_cfg,
1275         [SLAVE_SERVICE_CNOC] = &srvc_cnoc,
1276 };
1277
1278 static const struct regmap_config cnoc_regmap_config = {
1279         .reg_bits       = 32,
1280         .reg_stride     = 4,
1281         .val_bits       = 32,
1282         .max_register   = 0x6200,
1283         .fast_io        = true,
1284 };
1285
1286 static const struct qcom_icc_desc sm6115_config_noc = {
1287         .type = QCOM_ICC_QNOC,
1288         .nodes = config_noc_nodes,
1289         .num_nodes = ARRAY_SIZE(config_noc_nodes),
1290         .regmap_cfg = &cnoc_regmap_config,
1291         .intf_clocks = cnoc_intf_clocks,
1292         .num_intf_clocks = ARRAY_SIZE(cnoc_intf_clocks),
1293         .bus_clk_desc = &bus_1_clk,
1294         .keep_alive = true,
1295 };
1296
1297 static struct qcom_icc_node * const sys_noc_nodes[] = {
1298         [MASTER_CRYPTO_CORE0] = &crypto_c0,
1299         [MASTER_SNOC_CFG] = &qhm_snoc_cfg,
1300         [MASTER_TIC] = &qhm_tic,
1301         [MASTER_ANOC_SNOC] = &mas_anoc_snoc,
1302         [BIMC_SNOC_MAS] = &mas_bimc_snoc,
1303         [MASTER_PIMEM] = &qxm_pimem,
1304         [MASTER_QDSS_BAM] = &qhm_qdss_bam,
1305         [MASTER_QPIC] = &qhm_qpic,
1306         [MASTER_QUP_0] = &qhm_qup0,
1307         [MASTER_IPA] = &qxm_ipa,
1308         [MASTER_QDSS_ETR] = &xm_qdss_etr,
1309         [MASTER_SDCC_1] = &xm_sdc1,
1310         [MASTER_SDCC_2] = &xm_sdc2,
1311         [MASTER_USB3] = &xm_usb3_0,
1312         [SLAVE_APPSS] = &qhs_apss,
1313         [SNOC_CNOC_SLV] = &slv_snoc_cnoc,
1314         [SLAVE_OCIMEM] = &qxs_imem,
1315         [SLAVE_PIMEM] = &qxs_pimem,
1316         [SNOC_BIMC_SLV] = &slv_snoc_bimc,
1317         [SLAVE_SERVICE_SNOC] = &srvc_snoc,
1318         [SLAVE_QDSS_STM] = &xs_qdss_stm,
1319         [SLAVE_TCU] = &xs_sys_tcu_cfg,
1320         [SLAVE_ANOC_SNOC] = &slv_anoc_snoc,
1321 };
1322
1323 static const struct regmap_config sys_noc_regmap_config = {
1324         .reg_bits       = 32,
1325         .reg_stride     = 4,
1326         .val_bits       = 32,
1327         .max_register   = 0x5f080,
1328         .fast_io        = true,
1329 };
1330
1331 static const struct qcom_icc_desc sm6115_sys_noc = {
1332         .type = QCOM_ICC_QNOC,
1333         .nodes = sys_noc_nodes,
1334         .num_nodes = ARRAY_SIZE(sys_noc_nodes),
1335         .regmap_cfg = &sys_noc_regmap_config,
1336         .intf_clocks = snoc_intf_clocks,
1337         .num_intf_clocks = ARRAY_SIZE(snoc_intf_clocks),
1338         .bus_clk_desc = &bus_2_clk,
1339         .keep_alive = true,
1340 };
1341
1342 static struct qcom_icc_node * const clk_virt_nodes[] = {
1343         [MASTER_QUP_CORE_0] = &qup0_core_master,
1344         [SLAVE_QUP_CORE_0] = &qup0_core_slave,
1345 };
1346
1347 static const struct qcom_icc_desc sm6115_clk_virt = {
1348         .type = QCOM_ICC_QNOC,
1349         .nodes = clk_virt_nodes,
1350         .num_nodes = ARRAY_SIZE(clk_virt_nodes),
1351         .regmap_cfg = &sys_noc_regmap_config,
1352         .bus_clk_desc = &qup_clk,
1353         .keep_alive = true,
1354 };
1355
1356 static struct qcom_icc_node * const mmnrt_virt_nodes[] = {
1357         [MASTER_CAMNOC_SF] = &qnm_camera_nrt,
1358         [MASTER_VIDEO_P0] = &qxm_venus0,
1359         [MASTER_VIDEO_PROC] = &qxm_venus_cpu,
1360         [SLAVE_SNOC_BIMC_NRT] = &slv_snoc_bimc_nrt,
1361 };
1362
1363 static const struct qcom_icc_desc sm6115_mmnrt_virt = {
1364         .type = QCOM_ICC_QNOC,
1365         .nodes = mmnrt_virt_nodes,
1366         .num_nodes = ARRAY_SIZE(mmnrt_virt_nodes),
1367         .regmap_cfg = &sys_noc_regmap_config,
1368         .bus_clk_desc = &mmaxi_0_clk,
1369         .keep_alive = true,
1370         .ab_coeff = 142,
1371 };
1372
1373 static struct qcom_icc_node * const mmrt_virt_nodes[] = {
1374         [MASTER_CAMNOC_HF] = &qnm_camera_rt,
1375         [MASTER_MDP_PORT0] = &qxm_mdp0,
1376         [SLAVE_SNOC_BIMC_RT] = &slv_snoc_bimc_rt,
1377 };
1378
1379 static const struct qcom_icc_desc sm6115_mmrt_virt = {
1380         .type = QCOM_ICC_QNOC,
1381         .nodes = mmrt_virt_nodes,
1382         .num_nodes = ARRAY_SIZE(mmrt_virt_nodes),
1383         .regmap_cfg = &sys_noc_regmap_config,
1384         .bus_clk_desc = &mmaxi_1_clk,
1385         .keep_alive = true,
1386         .ab_coeff = 139,
1387 };
1388
1389 static const struct of_device_id qnoc_of_match[] = {
1390         { .compatible = "qcom,sm6115-bimc", .data = &sm6115_bimc },
1391         { .compatible = "qcom,sm6115-clk-virt", .data = &sm6115_clk_virt },
1392         { .compatible = "qcom,sm6115-cnoc", .data = &sm6115_config_noc },
1393         { .compatible = "qcom,sm6115-mmrt-virt", .data = &sm6115_mmrt_virt },
1394         { .compatible = "qcom,sm6115-mmnrt-virt", .data = &sm6115_mmnrt_virt },
1395         { .compatible = "qcom,sm6115-snoc", .data = &sm6115_sys_noc },
1396         { }
1397 };
1398 MODULE_DEVICE_TABLE(of, qnoc_of_match);
1399
1400 static struct platform_driver qnoc_driver = {
1401         .probe = qnoc_probe,
1402         .remove_new = qnoc_remove,
1403         .driver = {
1404                 .name = "qnoc-sm6115",
1405                 .of_match_table = qnoc_of_match,
1406                 .sync_state = icc_sync_state,
1407         },
1408 };
1409
1410 static int __init qnoc_driver_init(void)
1411 {
1412         return platform_driver_register(&qnoc_driver);
1413 }
1414 core_initcall(qnoc_driver_init);
1415
1416 static void __exit qnoc_driver_exit(void)
1417 {
1418         platform_driver_unregister(&qnoc_driver);
1419 }
1420 module_exit(qnoc_driver_exit);
1421
1422 MODULE_DESCRIPTION("SM6115 NoC driver");
1423 MODULE_LICENSE("GPL");