xref: /linux/drivers/interconnect/qcom/sm6115.c (revision cbc16bceea784210d585a42ac9f8f10ce62b300e)
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 = 22,
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 = 4,
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 = 9,
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 = 13,
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 = 10,
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 = 5,
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 = 8,
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 = 20,
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 = 2,
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 = 0,
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 = 3,
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 = 12,
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 = 17,
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 = 23,
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 = 24,
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 	.qos_offset = 0x15000,
1340 	.keep_alive = true,
1341 };
1342 
1343 static struct qcom_icc_node * const clk_virt_nodes[] = {
1344 	[MASTER_QUP_CORE_0] = &qup0_core_master,
1345 	[SLAVE_QUP_CORE_0] = &qup0_core_slave,
1346 };
1347 
1348 static const struct qcom_icc_desc sm6115_clk_virt = {
1349 	.type = QCOM_ICC_QNOC,
1350 	.nodes = clk_virt_nodes,
1351 	.num_nodes = ARRAY_SIZE(clk_virt_nodes),
1352 	.regmap_cfg = &sys_noc_regmap_config,
1353 	.bus_clk_desc = &qup_clk,
1354 	.keep_alive = true,
1355 };
1356 
1357 static struct qcom_icc_node * const mmnrt_virt_nodes[] = {
1358 	[MASTER_CAMNOC_SF] = &qnm_camera_nrt,
1359 	[MASTER_VIDEO_P0] = &qxm_venus0,
1360 	[MASTER_VIDEO_PROC] = &qxm_venus_cpu,
1361 	[SLAVE_SNOC_BIMC_NRT] = &slv_snoc_bimc_nrt,
1362 };
1363 
1364 static const struct qcom_icc_desc sm6115_mmnrt_virt = {
1365 	.type = QCOM_ICC_QNOC,
1366 	.nodes = mmnrt_virt_nodes,
1367 	.num_nodes = ARRAY_SIZE(mmnrt_virt_nodes),
1368 	.regmap_cfg = &sys_noc_regmap_config,
1369 	.bus_clk_desc = &mmaxi_0_clk,
1370 	.keep_alive = true,
1371 	.qos_offset = 0x15000,
1372 	.ab_coeff = 142,
1373 };
1374 
1375 static struct qcom_icc_node * const mmrt_virt_nodes[] = {
1376 	[MASTER_CAMNOC_HF] = &qnm_camera_rt,
1377 	[MASTER_MDP_PORT0] = &qxm_mdp0,
1378 	[SLAVE_SNOC_BIMC_RT] = &slv_snoc_bimc_rt,
1379 };
1380 
1381 static const struct qcom_icc_desc sm6115_mmrt_virt = {
1382 	.type = QCOM_ICC_QNOC,
1383 	.nodes = mmrt_virt_nodes,
1384 	.num_nodes = ARRAY_SIZE(mmrt_virt_nodes),
1385 	.regmap_cfg = &sys_noc_regmap_config,
1386 	.bus_clk_desc = &mmaxi_1_clk,
1387 	.keep_alive = true,
1388 	.qos_offset = 0x15000,
1389 	.ab_coeff = 139,
1390 };
1391 
1392 static const struct of_device_id qnoc_of_match[] = {
1393 	{ .compatible = "qcom,sm6115-bimc", .data = &sm6115_bimc },
1394 	{ .compatible = "qcom,sm6115-clk-virt", .data = &sm6115_clk_virt },
1395 	{ .compatible = "qcom,sm6115-cnoc", .data = &sm6115_config_noc },
1396 	{ .compatible = "qcom,sm6115-mmrt-virt", .data = &sm6115_mmrt_virt },
1397 	{ .compatible = "qcom,sm6115-mmnrt-virt", .data = &sm6115_mmnrt_virt },
1398 	{ .compatible = "qcom,sm6115-snoc", .data = &sm6115_sys_noc },
1399 	{ }
1400 };
1401 MODULE_DEVICE_TABLE(of, qnoc_of_match);
1402 
1403 static struct platform_driver qnoc_driver = {
1404 	.probe = qnoc_probe,
1405 	.remove = qnoc_remove,
1406 	.driver = {
1407 		.name = "qnoc-sm6115",
1408 		.of_match_table = qnoc_of_match,
1409 		.sync_state = icc_sync_state,
1410 	},
1411 };
1412 
1413 static int __init qnoc_driver_init(void)
1414 {
1415 	return platform_driver_register(&qnoc_driver);
1416 }
1417 core_initcall(qnoc_driver_init);
1418 
1419 static void __exit qnoc_driver_exit(void)
1420 {
1421 	platform_driver_unregister(&qnoc_driver);
1422 }
1423 module_exit(qnoc_driver_exit);
1424 
1425 MODULE_DESCRIPTION("SM6115 NoC driver");
1426 MODULE_LICENSE("GPL");
1427