xref: /linux/drivers/interconnect/qcom/msm8996.c (revision eb01fe7abbe2d0b38824d2a93fdb4cc3eaf2ccc1)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Qualcomm MSM8996 Network-on-Chip (NoC) QoS driver
4  *
5  * Copyright (c) 2021 Yassine Oudjana <y.oudjana@protonmail.com>
6  */
7 
8 #include <linux/device.h>
9 #include <linux/interconnect-provider.h>
10 #include <linux/io.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 <dt-bindings/interconnect/qcom,msm8996.h>
17 
18 #include "icc-rpm.h"
19 #include "msm8996.h"
20 
21 static const char * const mm_intf_clocks[] = {
22 	"iface"
23 };
24 
25 static const char * const a0noc_intf_clocks[] = {
26 	"aggre0_snoc_axi",
27 	"aggre0_cnoc_ahb",
28 	"aggre0_noc_mpu_cfg"
29 };
30 
31 static const char * const a2noc_intf_clocks[] = {
32 	"aggre2_ufs_axi",
33 	"ufs_axi"
34 };
35 
36 static const u16 mas_a0noc_common_links[] = {
37 	MSM8996_SLAVE_A0NOC_SNOC
38 };
39 
40 static struct qcom_icc_node mas_pcie_0 = {
41 	.name = "mas_pcie_0",
42 	.id = MSM8996_MASTER_PCIE_0,
43 	.buswidth = 8,
44 	.mas_rpm_id = 65,
45 	.slv_rpm_id = -1,
46 	.qos.ap_owned = true,
47 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
48 	.qos.areq_prio = 1,
49 	.qos.prio_level = 1,
50 	.qos.qos_port = 0,
51 	.num_links = ARRAY_SIZE(mas_a0noc_common_links),
52 	.links = mas_a0noc_common_links
53 };
54 
55 static struct qcom_icc_node mas_pcie_1 = {
56 	.name = "mas_pcie_1",
57 	.id = MSM8996_MASTER_PCIE_1,
58 	.buswidth = 8,
59 	.mas_rpm_id = 66,
60 	.slv_rpm_id = -1,
61 	.qos.ap_owned = true,
62 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
63 	.qos.areq_prio = 1,
64 	.qos.prio_level = 1,
65 	.qos.qos_port = 1,
66 	.num_links = ARRAY_SIZE(mas_a0noc_common_links),
67 	.links = mas_a0noc_common_links
68 };
69 
70 static struct qcom_icc_node mas_pcie_2 = {
71 	.name = "mas_pcie_2",
72 	.id = MSM8996_MASTER_PCIE_2,
73 	.buswidth = 8,
74 	.mas_rpm_id = 119,
75 	.slv_rpm_id = -1,
76 	.qos.ap_owned = true,
77 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
78 	.qos.areq_prio = 1,
79 	.qos.prio_level = 1,
80 	.qos.qos_port = 2,
81 	.num_links = ARRAY_SIZE(mas_a0noc_common_links),
82 	.links = mas_a0noc_common_links
83 };
84 
85 static const u16 mas_a1noc_common_links[] = {
86 	MSM8996_SLAVE_A1NOC_SNOC
87 };
88 
89 static struct qcom_icc_node mas_cnoc_a1noc = {
90 	.name = "mas_cnoc_a1noc",
91 	.id = MSM8996_MASTER_CNOC_A1NOC,
92 	.buswidth = 8,
93 	.mas_rpm_id = 116,
94 	.slv_rpm_id = -1,
95 	.qos.ap_owned = true,
96 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
97 	.num_links = ARRAY_SIZE(mas_a1noc_common_links),
98 	.links = mas_a1noc_common_links
99 };
100 
101 static struct qcom_icc_node mas_crypto_c0 = {
102 	.name = "mas_crypto_c0",
103 	.id = MSM8996_MASTER_CRYPTO_CORE0,
104 	.buswidth = 8,
105 	.mas_rpm_id = 23,
106 	.slv_rpm_id = -1,
107 	.qos.ap_owned = true,
108 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
109 	.qos.areq_prio = 1,
110 	.qos.prio_level = 1,
111 	.qos.qos_port = 0,
112 	.num_links = ARRAY_SIZE(mas_a1noc_common_links),
113 	.links = mas_a1noc_common_links
114 };
115 
116 static struct qcom_icc_node mas_pnoc_a1noc = {
117 	.name = "mas_pnoc_a1noc",
118 	.id = MSM8996_MASTER_PNOC_A1NOC,
119 	.buswidth = 8,
120 	.mas_rpm_id = 117,
121 	.slv_rpm_id = -1,
122 	.qos.ap_owned = false,
123 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
124 	.qos.areq_prio = 0,
125 	.qos.prio_level = 0,
126 	.qos.qos_port = 1,
127 	.num_links = ARRAY_SIZE(mas_a1noc_common_links),
128 	.links = mas_a1noc_common_links
129 };
130 
131 static const u16 mas_a2noc_common_links[] = {
132 	MSM8996_SLAVE_A2NOC_SNOC
133 };
134 
135 static struct qcom_icc_node mas_usb3 = {
136 	.name = "mas_usb3",
137 	.id = MSM8996_MASTER_USB3,
138 	.buswidth = 8,
139 	.mas_rpm_id = 32,
140 	.slv_rpm_id = -1,
141 	.qos.ap_owned = true,
142 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
143 	.qos.areq_prio = 1,
144 	.qos.prio_level = 1,
145 	.qos.qos_port = 3,
146 	.num_links = ARRAY_SIZE(mas_a2noc_common_links),
147 	.links = mas_a2noc_common_links
148 };
149 
150 static struct qcom_icc_node mas_ipa = {
151 	.name = "mas_ipa",
152 	.id = MSM8996_MASTER_IPA,
153 	.buswidth = 8,
154 	.mas_rpm_id = 59,
155 	.slv_rpm_id = -1,
156 	.qos.ap_owned = true,
157 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
158 	.qos.areq_prio = 0,
159 	.qos.prio_level = 0,
160 	.qos.qos_port = -1,
161 	.num_links = ARRAY_SIZE(mas_a2noc_common_links),
162 	.links = mas_a2noc_common_links
163 };
164 
165 static struct qcom_icc_node mas_ufs = {
166 	.name = "mas_ufs",
167 	.id = MSM8996_MASTER_UFS,
168 	.buswidth = 8,
169 	.mas_rpm_id = 68,
170 	.slv_rpm_id = -1,
171 	.qos.ap_owned = true,
172 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
173 	.qos.areq_prio = 1,
174 	.qos.prio_level = 1,
175 	.qos.qos_port = 2,
176 	.num_links = ARRAY_SIZE(mas_a2noc_common_links),
177 	.links = mas_a2noc_common_links
178 };
179 
180 static const u16 mas_apps_proc_links[] = {
181 	MSM8996_SLAVE_BIMC_SNOC_1,
182 	MSM8996_SLAVE_EBI_CH0,
183 	MSM8996_SLAVE_BIMC_SNOC_0
184 };
185 
186 static struct qcom_icc_node mas_apps_proc = {
187 	.name = "mas_apps_proc",
188 	.id = MSM8996_MASTER_AMPSS_M0,
189 	.buswidth = 8,
190 	.mas_rpm_id = 0,
191 	.slv_rpm_id = -1,
192 	.qos.ap_owned = true,
193 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
194 	.qos.areq_prio = 0,
195 	.qos.prio_level = 0,
196 	.qos.qos_port = 0,
197 	.num_links = ARRAY_SIZE(mas_apps_proc_links),
198 	.links = mas_apps_proc_links
199 };
200 
201 static const u16 mas_oxili_common_links[] = {
202 	MSM8996_SLAVE_BIMC_SNOC_1,
203 	MSM8996_SLAVE_HMSS_L3,
204 	MSM8996_SLAVE_EBI_CH0,
205 	MSM8996_SLAVE_BIMC_SNOC_0
206 };
207 
208 static struct qcom_icc_node mas_oxili = {
209 	.name = "mas_oxili",
210 	.id = MSM8996_MASTER_GRAPHICS_3D,
211 	.buswidth = 8,
212 	.mas_rpm_id = 6,
213 	.slv_rpm_id = -1,
214 	.qos.ap_owned = true,
215 	.qos.qos_mode = NOC_QOS_MODE_BYPASS,
216 	.qos.areq_prio = 0,
217 	.qos.prio_level = 0,
218 	.qos.qos_port = 1,
219 	.num_links = ARRAY_SIZE(mas_oxili_common_links),
220 	.links = mas_oxili_common_links
221 };
222 
223 static struct qcom_icc_node mas_mnoc_bimc = {
224 	.name = "mas_mnoc_bimc",
225 	.id = MSM8996_MASTER_MNOC_BIMC,
226 	.buswidth = 8,
227 	.mas_rpm_id = 2,
228 	.slv_rpm_id = -1,
229 	.qos.ap_owned = true,
230 	.qos.qos_mode = NOC_QOS_MODE_BYPASS,
231 	.qos.areq_prio = 0,
232 	.qos.prio_level = 0,
233 	.qos.qos_port = 2,
234 	.num_links = ARRAY_SIZE(mas_oxili_common_links),
235 	.links = mas_oxili_common_links
236 };
237 
238 static const u16 mas_snoc_bimc_links[] = {
239 	MSM8996_SLAVE_HMSS_L3,
240 	MSM8996_SLAVE_EBI_CH0
241 };
242 
243 static struct qcom_icc_node mas_snoc_bimc = {
244 	.name = "mas_snoc_bimc",
245 	.id = MSM8996_MASTER_SNOC_BIMC,
246 	.buswidth = 8,
247 	.mas_rpm_id = 3,
248 	.slv_rpm_id = -1,
249 	.qos.ap_owned = false,
250 	.qos.qos_mode = NOC_QOS_MODE_BYPASS,
251 	.qos.areq_prio = 0,
252 	.qos.prio_level = 0,
253 	.qos.qos_port = -1,
254 	.num_links = ARRAY_SIZE(mas_snoc_bimc_links),
255 	.links = mas_snoc_bimc_links
256 };
257 
258 static const u16 mas_snoc_cnoc_links[] = {
259 	MSM8996_SLAVE_CLK_CTL,
260 	MSM8996_SLAVE_RBCPR_CX,
261 	MSM8996_SLAVE_A2NOC_SMMU_CFG,
262 	MSM8996_SLAVE_A0NOC_MPU_CFG,
263 	MSM8996_SLAVE_MESSAGE_RAM,
264 	MSM8996_SLAVE_CNOC_MNOC_MMSS_CFG,
265 	MSM8996_SLAVE_PCIE_0_CFG,
266 	MSM8996_SLAVE_TLMM,
267 	MSM8996_SLAVE_MPM,
268 	MSM8996_SLAVE_A0NOC_SMMU_CFG,
269 	MSM8996_SLAVE_EBI1_PHY_CFG,
270 	MSM8996_SLAVE_BIMC_CFG,
271 	MSM8996_SLAVE_PIMEM_CFG,
272 	MSM8996_SLAVE_RBCPR_MX,
273 	MSM8996_SLAVE_PRNG,
274 	MSM8996_SLAVE_PCIE20_AHB2PHY,
275 	MSM8996_SLAVE_A2NOC_MPU_CFG,
276 	MSM8996_SLAVE_QDSS_CFG,
277 	MSM8996_SLAVE_A2NOC_CFG,
278 	MSM8996_SLAVE_A0NOC_CFG,
279 	MSM8996_SLAVE_UFS_CFG,
280 	MSM8996_SLAVE_CRYPTO_0_CFG,
281 	MSM8996_SLAVE_PCIE_1_CFG,
282 	MSM8996_SLAVE_SNOC_CFG,
283 	MSM8996_SLAVE_SNOC_MPU_CFG,
284 	MSM8996_SLAVE_A1NOC_MPU_CFG,
285 	MSM8996_SLAVE_A1NOC_SMMU_CFG,
286 	MSM8996_SLAVE_PCIE_2_CFG,
287 	MSM8996_SLAVE_CNOC_MNOC_CFG,
288 	MSM8996_SLAVE_QDSS_RBCPR_APU_CFG,
289 	MSM8996_SLAVE_PMIC_ARB,
290 	MSM8996_SLAVE_IMEM_CFG,
291 	MSM8996_SLAVE_A1NOC_CFG,
292 	MSM8996_SLAVE_SSC_CFG,
293 	MSM8996_SLAVE_TCSR,
294 	MSM8996_SLAVE_LPASS_SMMU_CFG,
295 	MSM8996_SLAVE_DCC_CFG
296 };
297 
298 static struct qcom_icc_node mas_snoc_cnoc = {
299 	.name = "mas_snoc_cnoc",
300 	.id = MSM8996_MASTER_SNOC_CNOC,
301 	.buswidth = 8,
302 	.mas_rpm_id = 52,
303 	.slv_rpm_id = -1,
304 	.num_links = ARRAY_SIZE(mas_snoc_cnoc_links),
305 	.links = mas_snoc_cnoc_links
306 };
307 
308 static const u16 mas_qdss_dap_links[] = {
309 	MSM8996_SLAVE_QDSS_RBCPR_APU_CFG,
310 	MSM8996_SLAVE_RBCPR_CX,
311 	MSM8996_SLAVE_A2NOC_SMMU_CFG,
312 	MSM8996_SLAVE_A0NOC_MPU_CFG,
313 	MSM8996_SLAVE_MESSAGE_RAM,
314 	MSM8996_SLAVE_PCIE_0_CFG,
315 	MSM8996_SLAVE_TLMM,
316 	MSM8996_SLAVE_MPM,
317 	MSM8996_SLAVE_A0NOC_SMMU_CFG,
318 	MSM8996_SLAVE_EBI1_PHY_CFG,
319 	MSM8996_SLAVE_BIMC_CFG,
320 	MSM8996_SLAVE_PIMEM_CFG,
321 	MSM8996_SLAVE_RBCPR_MX,
322 	MSM8996_SLAVE_CLK_CTL,
323 	MSM8996_SLAVE_PRNG,
324 	MSM8996_SLAVE_PCIE20_AHB2PHY,
325 	MSM8996_SLAVE_A2NOC_MPU_CFG,
326 	MSM8996_SLAVE_QDSS_CFG,
327 	MSM8996_SLAVE_A2NOC_CFG,
328 	MSM8996_SLAVE_A0NOC_CFG,
329 	MSM8996_SLAVE_UFS_CFG,
330 	MSM8996_SLAVE_CRYPTO_0_CFG,
331 	MSM8996_SLAVE_CNOC_A1NOC,
332 	MSM8996_SLAVE_PCIE_1_CFG,
333 	MSM8996_SLAVE_SNOC_CFG,
334 	MSM8996_SLAVE_SNOC_MPU_CFG,
335 	MSM8996_SLAVE_A1NOC_MPU_CFG,
336 	MSM8996_SLAVE_A1NOC_SMMU_CFG,
337 	MSM8996_SLAVE_PCIE_2_CFG,
338 	MSM8996_SLAVE_CNOC_MNOC_CFG,
339 	MSM8996_SLAVE_CNOC_MNOC_MMSS_CFG,
340 	MSM8996_SLAVE_PMIC_ARB,
341 	MSM8996_SLAVE_IMEM_CFG,
342 	MSM8996_SLAVE_A1NOC_CFG,
343 	MSM8996_SLAVE_SSC_CFG,
344 	MSM8996_SLAVE_TCSR,
345 	MSM8996_SLAVE_LPASS_SMMU_CFG,
346 	MSM8996_SLAVE_DCC_CFG
347 };
348 
349 static struct qcom_icc_node mas_qdss_dap = {
350 	.name = "mas_qdss_dap",
351 	.id = MSM8996_MASTER_QDSS_DAP,
352 	.buswidth = 8,
353 	.mas_rpm_id = 49,
354 	.slv_rpm_id = -1,
355 	.qos.ap_owned = true,
356 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
357 	.num_links = ARRAY_SIZE(mas_qdss_dap_links),
358 	.links = mas_qdss_dap_links
359 };
360 
361 static const u16 mas_cnoc_mnoc_mmss_cfg_links[] = {
362 	MSM8996_SLAVE_MMAGIC_CFG,
363 	MSM8996_SLAVE_DSA_MPU_CFG,
364 	MSM8996_SLAVE_MMSS_CLK_CFG,
365 	MSM8996_SLAVE_CAMERA_THROTTLE_CFG,
366 	MSM8996_SLAVE_VENUS_CFG,
367 	MSM8996_SLAVE_SMMU_VFE_CFG,
368 	MSM8996_SLAVE_MISC_CFG,
369 	MSM8996_SLAVE_SMMU_CPP_CFG,
370 	MSM8996_SLAVE_GRAPHICS_3D_CFG,
371 	MSM8996_SLAVE_DISPLAY_THROTTLE_CFG,
372 	MSM8996_SLAVE_VENUS_THROTTLE_CFG,
373 	MSM8996_SLAVE_CAMERA_CFG,
374 	MSM8996_SLAVE_DISPLAY_CFG,
375 	MSM8996_SLAVE_CPR_CFG,
376 	MSM8996_SLAVE_SMMU_ROTATOR_CFG,
377 	MSM8996_SLAVE_DSA_CFG,
378 	MSM8996_SLAVE_SMMU_VENUS_CFG,
379 	MSM8996_SLAVE_VMEM_CFG,
380 	MSM8996_SLAVE_SMMU_JPEG_CFG,
381 	MSM8996_SLAVE_SMMU_MDP_CFG,
382 	MSM8996_SLAVE_MNOC_MPU_CFG
383 };
384 
385 static struct qcom_icc_node mas_cnoc_mnoc_mmss_cfg = {
386 	.name = "mas_cnoc_mnoc_mmss_cfg",
387 	.id = MSM8996_MASTER_CNOC_MNOC_MMSS_CFG,
388 	.buswidth = 8,
389 	.mas_rpm_id = 4,
390 	.slv_rpm_id = -1,
391 	.qos.ap_owned = true,
392 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
393 	.num_links = ARRAY_SIZE(mas_cnoc_mnoc_mmss_cfg_links),
394 	.links = mas_cnoc_mnoc_mmss_cfg_links
395 };
396 
397 static const u16 mas_cnoc_mnoc_cfg_links[] = {
398 	MSM8996_SLAVE_SERVICE_MNOC
399 };
400 
401 static struct qcom_icc_node mas_cnoc_mnoc_cfg = {
402 	.name = "mas_cnoc_mnoc_cfg",
403 	.id = MSM8996_MASTER_CNOC_MNOC_CFG,
404 	.buswidth = 8,
405 	.mas_rpm_id = 5,
406 	.slv_rpm_id = -1,
407 	.qos.ap_owned = true,
408 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
409 	.num_links = ARRAY_SIZE(mas_cnoc_mnoc_cfg_links),
410 	.links = mas_cnoc_mnoc_cfg_links
411 };
412 
413 static const u16 mas_mnoc_bimc_common_links[] = {
414 	MSM8996_SLAVE_MNOC_BIMC
415 };
416 
417 static struct qcom_icc_node mas_cpp = {
418 	.name = "mas_cpp",
419 	.id = MSM8996_MASTER_CPP,
420 	.buswidth = 32,
421 	.mas_rpm_id = 115,
422 	.slv_rpm_id = -1,
423 	.qos.ap_owned = true,
424 	.qos.qos_mode = NOC_QOS_MODE_BYPASS,
425 	.qos.areq_prio = 0,
426 	.qos.prio_level = 0,
427 	.qos.qos_port = 5,
428 	.num_links = ARRAY_SIZE(mas_mnoc_bimc_common_links),
429 	.links = mas_mnoc_bimc_common_links
430 };
431 
432 static struct qcom_icc_node mas_jpeg = {
433 	.name = "mas_jpeg",
434 	.id = MSM8996_MASTER_JPEG,
435 	.buswidth = 32,
436 	.mas_rpm_id = 7,
437 	.slv_rpm_id = -1,
438 	.qos.ap_owned = true,
439 	.qos.qos_mode = NOC_QOS_MODE_BYPASS,
440 	.qos.areq_prio = 0,
441 	.qos.prio_level = 0,
442 	.qos.qos_port = 7,
443 	.num_links = ARRAY_SIZE(mas_mnoc_bimc_common_links),
444 	.links = mas_mnoc_bimc_common_links
445 };
446 
447 static struct qcom_icc_node mas_mdp_p0 = {
448 	.name = "mas_mdp_p0",
449 	.id = MSM8996_MASTER_MDP_PORT0,
450 	.buswidth = 32,
451 	.ib_coeff = 25,
452 	.mas_rpm_id = 8,
453 	.slv_rpm_id = -1,
454 	.qos.ap_owned = true,
455 	.qos.qos_mode = NOC_QOS_MODE_BYPASS,
456 	.qos.areq_prio = 0,
457 	.qos.prio_level = 0,
458 	.qos.qos_port = 1,
459 	.num_links = ARRAY_SIZE(mas_mnoc_bimc_common_links),
460 	.links = mas_mnoc_bimc_common_links
461 };
462 
463 static struct qcom_icc_node mas_mdp_p1 = {
464 	.name = "mas_mdp_p1",
465 	.id = MSM8996_MASTER_MDP_PORT1,
466 	.buswidth = 32,
467 	.ib_coeff = 25,
468 	.mas_rpm_id = 61,
469 	.slv_rpm_id = -1,
470 	.qos.ap_owned = true,
471 	.qos.qos_mode = NOC_QOS_MODE_BYPASS,
472 	.qos.areq_prio = 0,
473 	.qos.prio_level = 0,
474 	.qos.qos_port = 2,
475 	.num_links = ARRAY_SIZE(mas_mnoc_bimc_common_links),
476 	.links = mas_mnoc_bimc_common_links
477 };
478 
479 static struct qcom_icc_node mas_rotator = {
480 	.name = "mas_rotator",
481 	.id = MSM8996_MASTER_ROTATOR,
482 	.buswidth = 32,
483 	.mas_rpm_id = 120,
484 	.slv_rpm_id = -1,
485 	.qos.ap_owned = true,
486 	.qos.qos_mode = NOC_QOS_MODE_BYPASS,
487 	.qos.areq_prio = 0,
488 	.qos.prio_level = 0,
489 	.qos.qos_port = 0,
490 	.num_links = ARRAY_SIZE(mas_mnoc_bimc_common_links),
491 	.links = mas_mnoc_bimc_common_links
492 };
493 
494 static struct qcom_icc_node mas_venus = {
495 	.name = "mas_venus",
496 	.id = MSM8996_MASTER_VIDEO_P0,
497 	.buswidth = 32,
498 	.mas_rpm_id = 9,
499 	.slv_rpm_id = -1,
500 	.qos.ap_owned = true,
501 	.qos.qos_mode = NOC_QOS_MODE_BYPASS,
502 	.qos.areq_prio = 0,
503 	.qos.prio_level = 0,
504 	.qos.qos_port = 3,
505 	.num_links = ARRAY_SIZE(mas_mnoc_bimc_common_links),
506 	.links = mas_mnoc_bimc_common_links
507 };
508 
509 static struct qcom_icc_node mas_vfe = {
510 	.name = "mas_vfe",
511 	.id = MSM8996_MASTER_VFE,
512 	.buswidth = 32,
513 	.mas_rpm_id = 11,
514 	.slv_rpm_id = -1,
515 	.qos.ap_owned = true,
516 	.qos.qos_mode = NOC_QOS_MODE_BYPASS,
517 	.qos.areq_prio = 0,
518 	.qos.prio_level = 0,
519 	.qos.qos_port = 6,
520 	.num_links = ARRAY_SIZE(mas_mnoc_bimc_common_links),
521 	.links = mas_mnoc_bimc_common_links
522 };
523 
524 static const u16 mas_vmem_common_links[] = {
525 	MSM8996_SLAVE_VMEM
526 };
527 
528 static struct qcom_icc_node mas_snoc_vmem = {
529 	.name = "mas_snoc_vmem",
530 	.id = MSM8996_MASTER_SNOC_VMEM,
531 	.buswidth = 32,
532 	.mas_rpm_id = 114,
533 	.slv_rpm_id = -1,
534 	.qos.ap_owned = true,
535 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
536 	.num_links = ARRAY_SIZE(mas_vmem_common_links),
537 	.links = mas_vmem_common_links
538 };
539 
540 static struct qcom_icc_node mas_venus_vmem = {
541 	.name = "mas_venus_vmem",
542 	.id = MSM8996_MASTER_VIDEO_P0_OCMEM,
543 	.buswidth = 32,
544 	.mas_rpm_id = 121,
545 	.slv_rpm_id = -1,
546 	.qos.ap_owned = true,
547 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
548 	.num_links = ARRAY_SIZE(mas_vmem_common_links),
549 	.links = mas_vmem_common_links
550 };
551 
552 static const u16 mas_snoc_pnoc_links[] = {
553 	MSM8996_SLAVE_BLSP_1,
554 	MSM8996_SLAVE_BLSP_2,
555 	MSM8996_SLAVE_SDCC_1,
556 	MSM8996_SLAVE_SDCC_2,
557 	MSM8996_SLAVE_SDCC_4,
558 	MSM8996_SLAVE_TSIF,
559 	MSM8996_SLAVE_PDM,
560 	MSM8996_SLAVE_AHB2PHY
561 };
562 
563 static struct qcom_icc_node mas_snoc_pnoc = {
564 	.name = "mas_snoc_pnoc",
565 	.id = MSM8996_MASTER_SNOC_PNOC,
566 	.buswidth = 8,
567 	.mas_rpm_id = 44,
568 	.slv_rpm_id = -1,
569 	.num_links = ARRAY_SIZE(mas_snoc_pnoc_links),
570 	.links = mas_snoc_pnoc_links
571 };
572 
573 static const u16 mas_pnoc_a1noc_common_links[] = {
574 	MSM8996_SLAVE_PNOC_A1NOC
575 };
576 
577 static struct qcom_icc_node mas_sdcc_1 = {
578 	.name = "mas_sdcc_1",
579 	.id = MSM8996_MASTER_SDCC_1,
580 	.buswidth = 8,
581 	.mas_rpm_id = 33,
582 	.slv_rpm_id = -1,
583 	.num_links = ARRAY_SIZE(mas_pnoc_a1noc_common_links),
584 	.links = mas_pnoc_a1noc_common_links
585 };
586 
587 static struct qcom_icc_node mas_sdcc_2 = {
588 	.name = "mas_sdcc_2",
589 	.id = MSM8996_MASTER_SDCC_2,
590 	.buswidth = 8,
591 	.mas_rpm_id = 35,
592 	.slv_rpm_id = -1,
593 	.num_links = ARRAY_SIZE(mas_pnoc_a1noc_common_links),
594 	.links = mas_pnoc_a1noc_common_links
595 };
596 
597 static struct qcom_icc_node mas_sdcc_4 = {
598 	.name = "mas_sdcc_4",
599 	.id = MSM8996_MASTER_SDCC_4,
600 	.buswidth = 8,
601 	.mas_rpm_id = 36,
602 	.slv_rpm_id = -1,
603 	.num_links = ARRAY_SIZE(mas_pnoc_a1noc_common_links),
604 	.links = mas_pnoc_a1noc_common_links
605 };
606 
607 static struct qcom_icc_node mas_usb_hs = {
608 	.name = "mas_usb_hs",
609 	.id = MSM8996_MASTER_USB_HS,
610 	.buswidth = 8,
611 	.mas_rpm_id = 42,
612 	.slv_rpm_id = -1,
613 	.num_links = ARRAY_SIZE(mas_pnoc_a1noc_common_links),
614 	.links = mas_pnoc_a1noc_common_links
615 };
616 
617 static struct qcom_icc_node mas_blsp_1 = {
618 	.name = "mas_blsp_1",
619 	.id = MSM8996_MASTER_BLSP_1,
620 	.buswidth = 4,
621 	.mas_rpm_id = 41,
622 	.slv_rpm_id = -1,
623 	.num_links = ARRAY_SIZE(mas_pnoc_a1noc_common_links),
624 	.links = mas_pnoc_a1noc_common_links
625 };
626 
627 static struct qcom_icc_node mas_blsp_2 = {
628 	.name = "mas_blsp_2",
629 	.id = MSM8996_MASTER_BLSP_2,
630 	.buswidth = 4,
631 	.mas_rpm_id = 39,
632 	.slv_rpm_id = -1,
633 	.num_links = ARRAY_SIZE(mas_pnoc_a1noc_common_links),
634 	.links = mas_pnoc_a1noc_common_links
635 };
636 
637 static struct qcom_icc_node mas_tsif = {
638 	.name = "mas_tsif",
639 	.id = MSM8996_MASTER_TSIF,
640 	.buswidth = 4,
641 	.mas_rpm_id = 37,
642 	.slv_rpm_id = -1,
643 	.num_links = ARRAY_SIZE(mas_pnoc_a1noc_common_links),
644 	.links = mas_pnoc_a1noc_common_links
645 };
646 
647 static const u16 mas_hmss_links[] = {
648 	MSM8996_SLAVE_PIMEM,
649 	MSM8996_SLAVE_OCIMEM,
650 	MSM8996_SLAVE_SNOC_BIMC
651 };
652 
653 static struct qcom_icc_node mas_hmss = {
654 	.name = "mas_hmss",
655 	.id = MSM8996_MASTER_HMSS,
656 	.buswidth = 8,
657 	.mas_rpm_id = 118,
658 	.slv_rpm_id = -1,
659 	.qos.ap_owned = true,
660 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
661 	.qos.areq_prio = 1,
662 	.qos.prio_level = 1,
663 	.qos.qos_port = 4,
664 	.num_links = ARRAY_SIZE(mas_hmss_links),
665 	.links = mas_hmss_links
666 };
667 
668 static const u16 mas_qdss_common_links[] = {
669 	MSM8996_SLAVE_PIMEM,
670 	MSM8996_SLAVE_USB3,
671 	MSM8996_SLAVE_OCIMEM,
672 	MSM8996_SLAVE_SNOC_BIMC,
673 	MSM8996_SLAVE_SNOC_PNOC
674 };
675 
676 static struct qcom_icc_node mas_qdss_bam = {
677 	.name = "mas_qdss_bam",
678 	.id = MSM8996_MASTER_QDSS_BAM,
679 	.buswidth = 16,
680 	.mas_rpm_id = 19,
681 	.slv_rpm_id = -1,
682 	.qos.ap_owned = true,
683 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
684 	.qos.areq_prio = 1,
685 	.qos.prio_level = 1,
686 	.qos.qos_port = 2,
687 	.num_links = ARRAY_SIZE(mas_qdss_common_links),
688 	.links = mas_qdss_common_links
689 };
690 
691 static const u16 mas_snoc_cfg_links[] = {
692 	MSM8996_SLAVE_SERVICE_SNOC
693 };
694 
695 static struct qcom_icc_node mas_snoc_cfg = {
696 	.name = "mas_snoc_cfg",
697 	.id = MSM8996_MASTER_SNOC_CFG,
698 	.buswidth = 16,
699 	.mas_rpm_id = 20,
700 	.slv_rpm_id = -1,
701 	.qos.ap_owned = true,
702 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
703 	.num_links = ARRAY_SIZE(mas_snoc_cfg_links),
704 	.links = mas_snoc_cfg_links
705 };
706 
707 static const u16 mas_bimc_snoc_0_links[] = {
708 	MSM8996_SLAVE_SNOC_VMEM,
709 	MSM8996_SLAVE_USB3,
710 	MSM8996_SLAVE_PIMEM,
711 	MSM8996_SLAVE_LPASS,
712 	MSM8996_SLAVE_APPSS,
713 	MSM8996_SLAVE_SNOC_CNOC,
714 	MSM8996_SLAVE_SNOC_PNOC,
715 	MSM8996_SLAVE_OCIMEM,
716 	MSM8996_SLAVE_QDSS_STM
717 };
718 
719 static struct qcom_icc_node mas_bimc_snoc_0 = {
720 	.name = "mas_bimc_snoc_0",
721 	.id = MSM8996_MASTER_BIMC_SNOC_0,
722 	.buswidth = 16,
723 	.mas_rpm_id = 21,
724 	.slv_rpm_id = -1,
725 	.qos.ap_owned = true,
726 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
727 	.num_links = ARRAY_SIZE(mas_bimc_snoc_0_links),
728 	.links = mas_bimc_snoc_0_links
729 };
730 
731 static const u16 mas_bimc_snoc_1_links[] = {
732 	MSM8996_SLAVE_PCIE_2,
733 	MSM8996_SLAVE_PCIE_1,
734 	MSM8996_SLAVE_PCIE_0
735 };
736 
737 static struct qcom_icc_node mas_bimc_snoc_1 = {
738 	.name = "mas_bimc_snoc_1",
739 	.id = MSM8996_MASTER_BIMC_SNOC_1,
740 	.buswidth = 16,
741 	.mas_rpm_id = 109,
742 	.slv_rpm_id = -1,
743 	.qos.ap_owned = true,
744 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
745 	.num_links = ARRAY_SIZE(mas_bimc_snoc_1_links),
746 	.links = mas_bimc_snoc_1_links
747 };
748 
749 static const u16 mas_a0noc_snoc_links[] = {
750 	MSM8996_SLAVE_SNOC_PNOC,
751 	MSM8996_SLAVE_OCIMEM,
752 	MSM8996_SLAVE_APPSS,
753 	MSM8996_SLAVE_SNOC_BIMC,
754 	MSM8996_SLAVE_PIMEM
755 };
756 
757 static struct qcom_icc_node mas_a0noc_snoc = {
758 	.name = "mas_a0noc_snoc",
759 	.id = MSM8996_MASTER_A0NOC_SNOC,
760 	.buswidth = 16,
761 	.mas_rpm_id = 110,
762 	.slv_rpm_id = -1,
763 	.qos.ap_owned = true,
764 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
765 	.num_links = ARRAY_SIZE(mas_a0noc_snoc_links),
766 	.links = mas_a0noc_snoc_links
767 };
768 
769 static const u16 mas_a1noc_snoc_links[] = {
770 	MSM8996_SLAVE_SNOC_VMEM,
771 	MSM8996_SLAVE_USB3,
772 	MSM8996_SLAVE_PCIE_0,
773 	MSM8996_SLAVE_PIMEM,
774 	MSM8996_SLAVE_PCIE_2,
775 	MSM8996_SLAVE_LPASS,
776 	MSM8996_SLAVE_PCIE_1,
777 	MSM8996_SLAVE_APPSS,
778 	MSM8996_SLAVE_SNOC_BIMC,
779 	MSM8996_SLAVE_SNOC_CNOC,
780 	MSM8996_SLAVE_SNOC_PNOC,
781 	MSM8996_SLAVE_OCIMEM,
782 	MSM8996_SLAVE_QDSS_STM
783 };
784 
785 static struct qcom_icc_node mas_a1noc_snoc = {
786 	.name = "mas_a1noc_snoc",
787 	.id = MSM8996_MASTER_A1NOC_SNOC,
788 	.buswidth = 16,
789 	.mas_rpm_id = 111,
790 	.slv_rpm_id = -1,
791 	.num_links = ARRAY_SIZE(mas_a1noc_snoc_links),
792 	.links = mas_a1noc_snoc_links
793 };
794 
795 static const u16 mas_a2noc_snoc_links[] = {
796 	MSM8996_SLAVE_SNOC_VMEM,
797 	MSM8996_SLAVE_USB3,
798 	MSM8996_SLAVE_PCIE_1,
799 	MSM8996_SLAVE_PIMEM,
800 	MSM8996_SLAVE_PCIE_2,
801 	MSM8996_SLAVE_QDSS_STM,
802 	MSM8996_SLAVE_LPASS,
803 	MSM8996_SLAVE_SNOC_BIMC,
804 	MSM8996_SLAVE_SNOC_CNOC,
805 	MSM8996_SLAVE_SNOC_PNOC,
806 	MSM8996_SLAVE_OCIMEM,
807 	MSM8996_SLAVE_PCIE_0
808 };
809 
810 static struct qcom_icc_node mas_a2noc_snoc = {
811 	.name = "mas_a2noc_snoc",
812 	.id = MSM8996_MASTER_A2NOC_SNOC,
813 	.buswidth = 16,
814 	.mas_rpm_id = 112,
815 	.slv_rpm_id = -1,
816 	.num_links = ARRAY_SIZE(mas_a2noc_snoc_links),
817 	.links = mas_a2noc_snoc_links
818 };
819 
820 static struct qcom_icc_node mas_qdss_etr = {
821 	.name = "mas_qdss_etr",
822 	.id = MSM8996_MASTER_QDSS_ETR,
823 	.buswidth = 16,
824 	.mas_rpm_id = 31,
825 	.slv_rpm_id = -1,
826 	.qos.ap_owned = true,
827 	.qos.qos_mode = NOC_QOS_MODE_FIXED,
828 	.qos.areq_prio = 1,
829 	.qos.prio_level = 1,
830 	.qos.qos_port = 3,
831 	.num_links = ARRAY_SIZE(mas_qdss_common_links),
832 	.links = mas_qdss_common_links
833 };
834 
835 static const u16 slv_a0noc_snoc_links[] = {
836 	MSM8996_MASTER_A0NOC_SNOC
837 };
838 
839 static struct qcom_icc_node slv_a0noc_snoc = {
840 	.name = "slv_a0noc_snoc",
841 	.id = MSM8996_SLAVE_A0NOC_SNOC,
842 	.buswidth = 8,
843 	.mas_rpm_id = -1,
844 	.slv_rpm_id = 141,
845 	.qos.ap_owned = true,
846 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
847 	.num_links = ARRAY_SIZE(slv_a0noc_snoc_links),
848 	.links = slv_a0noc_snoc_links
849 };
850 
851 static const u16 slv_a1noc_snoc_links[] = {
852 	MSM8996_MASTER_A1NOC_SNOC
853 };
854 
855 static struct qcom_icc_node slv_a1noc_snoc = {
856 	.name = "slv_a1noc_snoc",
857 	.id = MSM8996_SLAVE_A1NOC_SNOC,
858 	.buswidth = 8,
859 	.mas_rpm_id = -1,
860 	.slv_rpm_id = 142,
861 	.num_links = ARRAY_SIZE(slv_a1noc_snoc_links),
862 	.links = slv_a1noc_snoc_links
863 };
864 
865 static const u16 slv_a2noc_snoc_links[] = {
866 	MSM8996_MASTER_A2NOC_SNOC
867 };
868 
869 static struct qcom_icc_node slv_a2noc_snoc = {
870 	.name = "slv_a2noc_snoc",
871 	.id = MSM8996_SLAVE_A2NOC_SNOC,
872 	.buswidth = 8,
873 	.mas_rpm_id = -1,
874 	.slv_rpm_id = 143,
875 	.num_links = ARRAY_SIZE(slv_a2noc_snoc_links),
876 	.links = slv_a2noc_snoc_links
877 };
878 
879 static struct qcom_icc_node slv_ebi = {
880 	.name = "slv_ebi",
881 	.id = MSM8996_SLAVE_EBI_CH0,
882 	.buswidth = 8,
883 	.mas_rpm_id = -1,
884 	.slv_rpm_id = 0
885 };
886 
887 static struct qcom_icc_node slv_hmss_l3 = {
888 	.name = "slv_hmss_l3",
889 	.id = MSM8996_SLAVE_HMSS_L3,
890 	.buswidth = 8,
891 	.mas_rpm_id = -1,
892 	.slv_rpm_id = 160
893 };
894 
895 static const u16 slv_bimc_snoc_0_links[] = {
896 	MSM8996_MASTER_BIMC_SNOC_0
897 };
898 
899 static struct qcom_icc_node slv_bimc_snoc_0 = {
900 	.name = "slv_bimc_snoc_0",
901 	.id = MSM8996_SLAVE_BIMC_SNOC_0,
902 	.buswidth = 8,
903 	.mas_rpm_id = -1,
904 	.slv_rpm_id = 2,
905 	.qos.ap_owned = true,
906 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
907 	.num_links = ARRAY_SIZE(slv_bimc_snoc_0_links),
908 	.links = slv_bimc_snoc_0_links
909 };
910 
911 static const u16 slv_bimc_snoc_1_links[] = {
912 	MSM8996_MASTER_BIMC_SNOC_1
913 };
914 
915 static struct qcom_icc_node slv_bimc_snoc_1 = {
916 	.name = "slv_bimc_snoc_1",
917 	.id = MSM8996_SLAVE_BIMC_SNOC_1,
918 	.buswidth = 8,
919 	.mas_rpm_id = -1,
920 	.slv_rpm_id = 138,
921 	.qos.ap_owned = true,
922 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
923 	.num_links = ARRAY_SIZE(slv_bimc_snoc_1_links),
924 	.links = slv_bimc_snoc_1_links
925 };
926 
927 static const u16 slv_cnoc_a1noc_links[] = {
928 	MSM8996_MASTER_CNOC_A1NOC
929 };
930 
931 static struct qcom_icc_node slv_cnoc_a1noc = {
932 	.name = "slv_cnoc_a1noc",
933 	.id = MSM8996_SLAVE_CNOC_A1NOC,
934 	.buswidth = 4,
935 	.mas_rpm_id = -1,
936 	.slv_rpm_id = 75,
937 	.qos.ap_owned = true,
938 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
939 	.num_links = ARRAY_SIZE(slv_cnoc_a1noc_links),
940 	.links = slv_cnoc_a1noc_links
941 };
942 
943 static struct qcom_icc_node slv_clk_ctl = {
944 	.name = "slv_clk_ctl",
945 	.id = MSM8996_SLAVE_CLK_CTL,
946 	.buswidth = 4,
947 	.mas_rpm_id = -1,
948 	.slv_rpm_id = 47
949 };
950 
951 static struct qcom_icc_node slv_tcsr = {
952 	.name = "slv_tcsr",
953 	.id = MSM8996_SLAVE_TCSR,
954 	.buswidth = 4,
955 	.mas_rpm_id = -1,
956 	.slv_rpm_id = 50
957 };
958 
959 static struct qcom_icc_node slv_tlmm = {
960 	.name = "slv_tlmm",
961 	.id = MSM8996_SLAVE_TLMM,
962 	.buswidth = 4,
963 	.mas_rpm_id = -1,
964 	.slv_rpm_id = 51
965 };
966 
967 static struct qcom_icc_node slv_crypto0_cfg = {
968 	.name = "slv_crypto0_cfg",
969 	.id = MSM8996_SLAVE_CRYPTO_0_CFG,
970 	.buswidth = 4,
971 	.mas_rpm_id = -1,
972 	.slv_rpm_id = 52,
973 	.qos.ap_owned = true,
974 	.qos.qos_mode = NOC_QOS_MODE_INVALID
975 };
976 
977 static struct qcom_icc_node slv_mpm = {
978 	.name = "slv_mpm",
979 	.id = MSM8996_SLAVE_MPM,
980 	.buswidth = 4,
981 	.mas_rpm_id = -1,
982 	.slv_rpm_id = 62,
983 	.qos.ap_owned = true,
984 	.qos.qos_mode = NOC_QOS_MODE_INVALID
985 };
986 
987 static struct qcom_icc_node slv_pimem_cfg = {
988 	.name = "slv_pimem_cfg",
989 	.id = MSM8996_SLAVE_PIMEM_CFG,
990 	.buswidth = 4,
991 	.mas_rpm_id = -1,
992 	.slv_rpm_id = 167,
993 	.qos.ap_owned = true,
994 	.qos.qos_mode = NOC_QOS_MODE_INVALID
995 };
996 
997 static struct qcom_icc_node slv_imem_cfg = {
998 	.name = "slv_imem_cfg",
999 	.id = MSM8996_SLAVE_IMEM_CFG,
1000 	.buswidth = 4,
1001 	.mas_rpm_id = -1,
1002 	.slv_rpm_id = 54,
1003 	.qos.ap_owned = true,
1004 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1005 };
1006 
1007 static struct qcom_icc_node slv_message_ram = {
1008 	.name = "slv_message_ram",
1009 	.id = MSM8996_SLAVE_MESSAGE_RAM,
1010 	.buswidth = 4,
1011 	.mas_rpm_id = -1,
1012 	.slv_rpm_id = 55
1013 };
1014 
1015 static struct qcom_icc_node slv_bimc_cfg = {
1016 	.name = "slv_bimc_cfg",
1017 	.id = MSM8996_SLAVE_BIMC_CFG,
1018 	.buswidth = 4,
1019 	.mas_rpm_id = -1,
1020 	.slv_rpm_id = 56,
1021 	.qos.ap_owned = true,
1022 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1023 };
1024 
1025 static struct qcom_icc_node slv_pmic_arb = {
1026 	.name = "slv_pmic_arb",
1027 	.id = MSM8996_SLAVE_PMIC_ARB,
1028 	.buswidth = 4,
1029 	.mas_rpm_id = -1,
1030 	.slv_rpm_id = 59
1031 };
1032 
1033 static struct qcom_icc_node slv_prng = {
1034 	.name = "slv_prng",
1035 	.id = MSM8996_SLAVE_PRNG,
1036 	.buswidth = 4,
1037 	.mas_rpm_id = -1,
1038 	.slv_rpm_id = 127,
1039 	.qos.ap_owned = true,
1040 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1041 };
1042 
1043 static struct qcom_icc_node slv_dcc_cfg = {
1044 	.name = "slv_dcc_cfg",
1045 	.id = MSM8996_SLAVE_DCC_CFG,
1046 	.buswidth = 4,
1047 	.mas_rpm_id = -1,
1048 	.slv_rpm_id = 155,
1049 	.qos.ap_owned = true,
1050 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1051 };
1052 
1053 static struct qcom_icc_node slv_rbcpr_mx = {
1054 	.name = "slv_rbcpr_mx",
1055 	.id = MSM8996_SLAVE_RBCPR_MX,
1056 	.buswidth = 4,
1057 	.mas_rpm_id = -1,
1058 	.slv_rpm_id = 170,
1059 	.qos.ap_owned = true,
1060 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1061 };
1062 
1063 static struct qcom_icc_node slv_qdss_cfg = {
1064 	.name = "slv_qdss_cfg",
1065 	.id = MSM8996_SLAVE_QDSS_CFG,
1066 	.buswidth = 4,
1067 	.mas_rpm_id = -1,
1068 	.slv_rpm_id = 63,
1069 	.qos.ap_owned = true,
1070 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1071 };
1072 
1073 static struct qcom_icc_node slv_rbcpr_cx = {
1074 	.name = "slv_rbcpr_cx",
1075 	.id = MSM8996_SLAVE_RBCPR_CX,
1076 	.buswidth = 4,
1077 	.mas_rpm_id = -1,
1078 	.slv_rpm_id = 169,
1079 	.qos.ap_owned = true,
1080 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1081 };
1082 
1083 static struct qcom_icc_node slv_cpu_apu_cfg = {
1084 	.name = "slv_cpu_apu_cfg",
1085 	.id = MSM8996_SLAVE_QDSS_RBCPR_APU_CFG,
1086 	.buswidth = 4,
1087 	.mas_rpm_id = -1,
1088 	.slv_rpm_id = 168,
1089 	.qos.ap_owned = true,
1090 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1091 };
1092 
1093 static const u16 slv_cnoc_mnoc_cfg_links[] = {
1094 	MSM8996_MASTER_CNOC_MNOC_CFG
1095 };
1096 
1097 static struct qcom_icc_node slv_cnoc_mnoc_cfg = {
1098 	.name = "slv_cnoc_mnoc_cfg",
1099 	.id = MSM8996_SLAVE_CNOC_MNOC_CFG,
1100 	.buswidth = 4,
1101 	.mas_rpm_id = -1,
1102 	.slv_rpm_id = 66,
1103 	.qos.ap_owned = true,
1104 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
1105 	.num_links = ARRAY_SIZE(slv_cnoc_mnoc_cfg_links),
1106 	.links = slv_cnoc_mnoc_cfg_links
1107 };
1108 
1109 static struct qcom_icc_node slv_snoc_cfg = {
1110 	.name = "slv_snoc_cfg",
1111 	.id = MSM8996_SLAVE_SNOC_CFG,
1112 	.buswidth = 4,
1113 	.mas_rpm_id = -1,
1114 	.slv_rpm_id = 70,
1115 	.qos.ap_owned = true,
1116 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1117 };
1118 
1119 static struct qcom_icc_node slv_snoc_mpu_cfg = {
1120 	.name = "slv_snoc_mpu_cfg",
1121 	.id = MSM8996_SLAVE_SNOC_MPU_CFG,
1122 	.buswidth = 4,
1123 	.mas_rpm_id = -1,
1124 	.slv_rpm_id = 67,
1125 	.qos.ap_owned = true,
1126 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1127 };
1128 
1129 static struct qcom_icc_node slv_ebi1_phy_cfg = {
1130 	.name = "slv_ebi1_phy_cfg",
1131 	.id = MSM8996_SLAVE_EBI1_PHY_CFG,
1132 	.buswidth = 4,
1133 	.mas_rpm_id = -1,
1134 	.slv_rpm_id = 73,
1135 	.qos.ap_owned = true,
1136 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1137 };
1138 
1139 static struct qcom_icc_node slv_a0noc_cfg = {
1140 	.name = "slv_a0noc_cfg",
1141 	.id = MSM8996_SLAVE_A0NOC_CFG,
1142 	.buswidth = 4,
1143 	.mas_rpm_id = -1,
1144 	.slv_rpm_id = 144,
1145 	.qos.ap_owned = true,
1146 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1147 };
1148 
1149 static struct qcom_icc_node slv_pcie_1_cfg = {
1150 	.name = "slv_pcie_1_cfg",
1151 	.id = MSM8996_SLAVE_PCIE_1_CFG,
1152 	.buswidth = 4,
1153 	.mas_rpm_id = -1,
1154 	.slv_rpm_id = 89,
1155 	.qos.ap_owned = true,
1156 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1157 };
1158 
1159 static struct qcom_icc_node slv_pcie_2_cfg = {
1160 	.name = "slv_pcie_2_cfg",
1161 	.id = MSM8996_SLAVE_PCIE_2_CFG,
1162 	.buswidth = 4,
1163 	.mas_rpm_id = -1,
1164 	.slv_rpm_id = 165,
1165 	.qos.ap_owned = true,
1166 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1167 };
1168 
1169 static struct qcom_icc_node slv_pcie_0_cfg = {
1170 	.name = "slv_pcie_0_cfg",
1171 	.id = MSM8996_SLAVE_PCIE_0_CFG,
1172 	.buswidth = 4,
1173 	.mas_rpm_id = -1,
1174 	.slv_rpm_id = 88,
1175 	.qos.ap_owned = true,
1176 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1177 };
1178 
1179 static struct qcom_icc_node slv_pcie20_ahb2phy = {
1180 	.name = "slv_pcie20_ahb2phy",
1181 	.id = MSM8996_SLAVE_PCIE20_AHB2PHY,
1182 	.buswidth = 4,
1183 	.mas_rpm_id = -1,
1184 	.slv_rpm_id = 163,
1185 	.qos.ap_owned = true,
1186 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1187 };
1188 
1189 static struct qcom_icc_node slv_a0noc_mpu_cfg = {
1190 	.name = "slv_a0noc_mpu_cfg",
1191 	.id = MSM8996_SLAVE_A0NOC_MPU_CFG,
1192 	.buswidth = 4,
1193 	.mas_rpm_id = -1,
1194 	.slv_rpm_id = 145,
1195 	.qos.ap_owned = true,
1196 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1197 };
1198 
1199 static struct qcom_icc_node slv_ufs_cfg = {
1200 	.name = "slv_ufs_cfg",
1201 	.id = MSM8996_SLAVE_UFS_CFG,
1202 	.buswidth = 4,
1203 	.mas_rpm_id = -1,
1204 	.slv_rpm_id = 92,
1205 	.qos.ap_owned = true,
1206 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1207 };
1208 
1209 static struct qcom_icc_node slv_a1noc_cfg = {
1210 	.name = "slv_a1noc_cfg",
1211 	.id = MSM8996_SLAVE_A1NOC_CFG,
1212 	.buswidth = 4,
1213 	.mas_rpm_id = -1,
1214 	.slv_rpm_id = 147,
1215 	.qos.ap_owned = true,
1216 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1217 };
1218 
1219 static struct qcom_icc_node slv_a1noc_mpu_cfg = {
1220 	.name = "slv_a1noc_mpu_cfg",
1221 	.id = MSM8996_SLAVE_A1NOC_MPU_CFG,
1222 	.buswidth = 4,
1223 	.mas_rpm_id = -1,
1224 	.slv_rpm_id = 148,
1225 	.qos.ap_owned = true,
1226 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1227 };
1228 
1229 static struct qcom_icc_node slv_a2noc_cfg = {
1230 	.name = "slv_a2noc_cfg",
1231 	.id = MSM8996_SLAVE_A2NOC_CFG,
1232 	.buswidth = 4,
1233 	.mas_rpm_id = -1,
1234 	.slv_rpm_id = 150,
1235 	.qos.ap_owned = true,
1236 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1237 };
1238 
1239 static struct qcom_icc_node slv_a2noc_mpu_cfg = {
1240 	.name = "slv_a2noc_mpu_cfg",
1241 	.id = MSM8996_SLAVE_A2NOC_MPU_CFG,
1242 	.buswidth = 4,
1243 	.mas_rpm_id = -1,
1244 	.slv_rpm_id = 151,
1245 	.qos.ap_owned = true,
1246 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1247 };
1248 
1249 static struct qcom_icc_node slv_ssc_cfg = {
1250 	.name = "slv_ssc_cfg",
1251 	.id = MSM8996_SLAVE_SSC_CFG,
1252 	.buswidth = 4,
1253 	.mas_rpm_id = -1,
1254 	.slv_rpm_id = 177,
1255 	.qos.ap_owned = true,
1256 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1257 };
1258 
1259 static struct qcom_icc_node slv_a0noc_smmu_cfg = {
1260 	.name = "slv_a0noc_smmu_cfg",
1261 	.id = MSM8996_SLAVE_A0NOC_SMMU_CFG,
1262 	.buswidth = 8,
1263 	.mas_rpm_id = -1,
1264 	.slv_rpm_id = 146,
1265 	.qos.ap_owned = true,
1266 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1267 };
1268 
1269 static struct qcom_icc_node slv_a1noc_smmu_cfg = {
1270 	.name = "slv_a1noc_smmu_cfg",
1271 	.id = MSM8996_SLAVE_A1NOC_SMMU_CFG,
1272 	.buswidth = 8,
1273 	.mas_rpm_id = -1,
1274 	.slv_rpm_id = 149,
1275 	.qos.ap_owned = true,
1276 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1277 };
1278 
1279 static struct qcom_icc_node slv_a2noc_smmu_cfg = {
1280 	.name = "slv_a2noc_smmu_cfg",
1281 	.id = MSM8996_SLAVE_A2NOC_SMMU_CFG,
1282 	.buswidth = 8,
1283 	.mas_rpm_id = -1,
1284 	.slv_rpm_id = 152,
1285 	.qos.ap_owned = true,
1286 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1287 };
1288 
1289 static struct qcom_icc_node slv_lpass_smmu_cfg = {
1290 	.name = "slv_lpass_smmu_cfg",
1291 	.id = MSM8996_SLAVE_LPASS_SMMU_CFG,
1292 	.buswidth = 8,
1293 	.mas_rpm_id = -1,
1294 	.slv_rpm_id = 161,
1295 	.qos.ap_owned = true,
1296 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1297 };
1298 
1299 static const u16 slv_cnoc_mnoc_mmss_cfg_links[] = {
1300 	MSM8996_MASTER_CNOC_MNOC_MMSS_CFG
1301 };
1302 
1303 static struct qcom_icc_node slv_cnoc_mnoc_mmss_cfg = {
1304 	.name = "slv_cnoc_mnoc_mmss_cfg",
1305 	.id = MSM8996_SLAVE_CNOC_MNOC_MMSS_CFG,
1306 	.buswidth = 8,
1307 	.mas_rpm_id = -1,
1308 	.slv_rpm_id = 58,
1309 	.qos.ap_owned = true,
1310 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
1311 	.num_links = ARRAY_SIZE(slv_cnoc_mnoc_mmss_cfg_links),
1312 	.links = slv_cnoc_mnoc_mmss_cfg_links
1313 };
1314 
1315 static struct qcom_icc_node slv_mmagic_cfg = {
1316 	.name = "slv_mmagic_cfg",
1317 	.id = MSM8996_SLAVE_MMAGIC_CFG,
1318 	.buswidth = 8,
1319 	.mas_rpm_id = -1,
1320 	.slv_rpm_id = 162,
1321 	.qos.ap_owned = true,
1322 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1323 };
1324 
1325 static struct qcom_icc_node slv_cpr_cfg = {
1326 	.name = "slv_cpr_cfg",
1327 	.id = MSM8996_SLAVE_CPR_CFG,
1328 	.buswidth = 8,
1329 	.mas_rpm_id = -1,
1330 	.slv_rpm_id = 6,
1331 	.qos.ap_owned = true,
1332 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1333 };
1334 
1335 static struct qcom_icc_node slv_misc_cfg = {
1336 	.name = "slv_misc_cfg",
1337 	.id = MSM8996_SLAVE_MISC_CFG,
1338 	.buswidth = 8,
1339 	.mas_rpm_id = -1,
1340 	.slv_rpm_id = 8,
1341 	.qos.ap_owned = true,
1342 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1343 };
1344 
1345 static struct qcom_icc_node slv_venus_throttle_cfg = {
1346 	.name = "slv_venus_throttle_cfg",
1347 	.id = MSM8996_SLAVE_VENUS_THROTTLE_CFG,
1348 	.buswidth = 8,
1349 	.mas_rpm_id = -1,
1350 	.slv_rpm_id = 178,
1351 	.qos.ap_owned = true,
1352 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1353 };
1354 
1355 static struct qcom_icc_node slv_venus_cfg = {
1356 	.name = "slv_venus_cfg",
1357 	.id = MSM8996_SLAVE_VENUS_CFG,
1358 	.buswidth = 8,
1359 	.mas_rpm_id = -1,
1360 	.slv_rpm_id = 10,
1361 	.qos.ap_owned = true,
1362 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1363 };
1364 
1365 static struct qcom_icc_node slv_vmem_cfg = {
1366 	.name = "slv_vmem_cfg",
1367 	.id = MSM8996_SLAVE_VMEM_CFG,
1368 	.buswidth = 8,
1369 	.mas_rpm_id = -1,
1370 	.slv_rpm_id = 180,
1371 	.qos.ap_owned = true,
1372 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1373 };
1374 
1375 static struct qcom_icc_node slv_dsa_cfg = {
1376 	.name = "slv_dsa_cfg",
1377 	.id = MSM8996_SLAVE_DSA_CFG,
1378 	.buswidth = 8,
1379 	.mas_rpm_id = -1,
1380 	.slv_rpm_id = 157,
1381 	.qos.ap_owned = true,
1382 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1383 };
1384 
1385 static struct qcom_icc_node slv_mnoc_clocks_cfg = {
1386 	.name = "slv_mnoc_clocks_cfg",
1387 	.id = MSM8996_SLAVE_MMSS_CLK_CFG,
1388 	.buswidth = 8,
1389 	.mas_rpm_id = -1,
1390 	.slv_rpm_id = 12,
1391 	.qos.ap_owned = true,
1392 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1393 };
1394 
1395 static struct qcom_icc_node slv_dsa_mpu_cfg = {
1396 	.name = "slv_dsa_mpu_cfg",
1397 	.id = MSM8996_SLAVE_DSA_MPU_CFG,
1398 	.buswidth = 8,
1399 	.mas_rpm_id = -1,
1400 	.slv_rpm_id = 158,
1401 	.qos.ap_owned = true,
1402 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1403 };
1404 
1405 static struct qcom_icc_node slv_mnoc_mpu_cfg = {
1406 	.name = "slv_mnoc_mpu_cfg",
1407 	.id = MSM8996_SLAVE_MNOC_MPU_CFG,
1408 	.buswidth = 8,
1409 	.mas_rpm_id = -1,
1410 	.slv_rpm_id = 14,
1411 	.qos.ap_owned = true,
1412 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1413 };
1414 
1415 static struct qcom_icc_node slv_display_cfg = {
1416 	.name = "slv_display_cfg",
1417 	.id = MSM8996_SLAVE_DISPLAY_CFG,
1418 	.buswidth = 8,
1419 	.mas_rpm_id = -1,
1420 	.slv_rpm_id = 4,
1421 	.qos.ap_owned = true,
1422 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1423 };
1424 
1425 static struct qcom_icc_node slv_display_throttle_cfg = {
1426 	.name = "slv_display_throttle_cfg",
1427 	.id = MSM8996_SLAVE_DISPLAY_THROTTLE_CFG,
1428 	.buswidth = 8,
1429 	.mas_rpm_id = -1,
1430 	.slv_rpm_id = 156,
1431 	.qos.ap_owned = true,
1432 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1433 };
1434 
1435 static struct qcom_icc_node slv_camera_cfg = {
1436 	.name = "slv_camera_cfg",
1437 	.id = MSM8996_SLAVE_CAMERA_CFG,
1438 	.buswidth = 8,
1439 	.mas_rpm_id = -1,
1440 	.slv_rpm_id = 3,
1441 	.qos.ap_owned = true,
1442 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1443 };
1444 
1445 static struct qcom_icc_node slv_camera_throttle_cfg = {
1446 	.name = "slv_camera_throttle_cfg",
1447 	.id = MSM8996_SLAVE_CAMERA_THROTTLE_CFG,
1448 	.buswidth = 8,
1449 	.mas_rpm_id = -1,
1450 	.slv_rpm_id = 154,
1451 	.qos.ap_owned = true,
1452 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1453 };
1454 
1455 static struct qcom_icc_node slv_oxili_cfg = {
1456 	.name = "slv_oxili_cfg",
1457 	.id = MSM8996_SLAVE_GRAPHICS_3D_CFG,
1458 	.buswidth = 8,
1459 	.mas_rpm_id = -1,
1460 	.slv_rpm_id = 11,
1461 	.qos.ap_owned = true,
1462 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1463 };
1464 
1465 static struct qcom_icc_node slv_smmu_mdp_cfg = {
1466 	.name = "slv_smmu_mdp_cfg",
1467 	.id = MSM8996_SLAVE_SMMU_MDP_CFG,
1468 	.buswidth = 8,
1469 	.mas_rpm_id = -1,
1470 	.slv_rpm_id = 173,
1471 	.qos.ap_owned = true,
1472 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1473 };
1474 
1475 static struct qcom_icc_node slv_smmu_rot_cfg = {
1476 	.name = "slv_smmu_rot_cfg",
1477 	.id = MSM8996_SLAVE_SMMU_ROTATOR_CFG,
1478 	.buswidth = 8,
1479 	.mas_rpm_id = -1,
1480 	.slv_rpm_id = 174,
1481 	.qos.ap_owned = true,
1482 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1483 };
1484 
1485 static struct qcom_icc_node slv_smmu_venus_cfg = {
1486 	.name = "slv_smmu_venus_cfg",
1487 	.id = MSM8996_SLAVE_SMMU_VENUS_CFG,
1488 	.buswidth = 8,
1489 	.mas_rpm_id = -1,
1490 	.slv_rpm_id = 175,
1491 	.qos.ap_owned = true,
1492 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1493 };
1494 
1495 static struct qcom_icc_node slv_smmu_cpp_cfg = {
1496 	.name = "slv_smmu_cpp_cfg",
1497 	.id = MSM8996_SLAVE_SMMU_CPP_CFG,
1498 	.buswidth = 8,
1499 	.mas_rpm_id = -1,
1500 	.slv_rpm_id = 171,
1501 	.qos.ap_owned = true,
1502 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1503 };
1504 
1505 static struct qcom_icc_node slv_smmu_jpeg_cfg = {
1506 	.name = "slv_smmu_jpeg_cfg",
1507 	.id = MSM8996_SLAVE_SMMU_JPEG_CFG,
1508 	.buswidth = 8,
1509 	.mas_rpm_id = -1,
1510 	.slv_rpm_id = 172,
1511 	.qos.ap_owned = true,
1512 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1513 };
1514 
1515 static struct qcom_icc_node slv_smmu_vfe_cfg = {
1516 	.name = "slv_smmu_vfe_cfg",
1517 	.id = MSM8996_SLAVE_SMMU_VFE_CFG,
1518 	.buswidth = 8,
1519 	.mas_rpm_id = -1,
1520 	.slv_rpm_id = 176,
1521 	.qos.ap_owned = true,
1522 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1523 };
1524 
1525 static const u16 slv_mnoc_bimc_links[] = {
1526 	MSM8996_MASTER_MNOC_BIMC
1527 };
1528 
1529 static struct qcom_icc_node slv_mnoc_bimc = {
1530 	.name = "slv_mnoc_bimc",
1531 	.id = MSM8996_SLAVE_MNOC_BIMC,
1532 	.buswidth = 32,
1533 	.mas_rpm_id = -1,
1534 	.slv_rpm_id = 16,
1535 	.qos.ap_owned = true,
1536 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
1537 	.num_links = ARRAY_SIZE(slv_mnoc_bimc_links),
1538 	.links = slv_mnoc_bimc_links
1539 };
1540 
1541 static struct qcom_icc_node slv_vmem = {
1542 	.name = "slv_vmem",
1543 	.id = MSM8996_SLAVE_VMEM,
1544 	.buswidth = 32,
1545 	.mas_rpm_id = -1,
1546 	.slv_rpm_id = 179,
1547 	.qos.ap_owned = true,
1548 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1549 };
1550 
1551 static struct qcom_icc_node slv_srvc_mnoc = {
1552 	.name = "slv_srvc_mnoc",
1553 	.id = MSM8996_SLAVE_SERVICE_MNOC,
1554 	.buswidth = 8,
1555 	.mas_rpm_id = -1,
1556 	.slv_rpm_id = 17,
1557 	.qos.ap_owned = true,
1558 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1559 };
1560 
1561 static const u16 slv_pnoc_a1noc_links[] = {
1562 	MSM8996_MASTER_PNOC_A1NOC
1563 };
1564 
1565 static struct qcom_icc_node slv_pnoc_a1noc = {
1566 	.name = "slv_pnoc_a1noc",
1567 	.id = MSM8996_SLAVE_PNOC_A1NOC,
1568 	.buswidth = 8,
1569 	.mas_rpm_id = -1,
1570 	.slv_rpm_id = 139,
1571 	.num_links = ARRAY_SIZE(slv_pnoc_a1noc_links),
1572 	.links = slv_pnoc_a1noc_links
1573 };
1574 
1575 static struct qcom_icc_node slv_usb_hs = {
1576 	.name = "slv_usb_hs",
1577 	.id = MSM8996_SLAVE_USB_HS,
1578 	.buswidth = 4,
1579 	.mas_rpm_id = -1,
1580 	.slv_rpm_id = 40
1581 };
1582 
1583 static struct qcom_icc_node slv_sdcc_2 = {
1584 	.name = "slv_sdcc_2",
1585 	.id = MSM8996_SLAVE_SDCC_2,
1586 	.buswidth = 4,
1587 	.mas_rpm_id = -1,
1588 	.slv_rpm_id = 33
1589 };
1590 
1591 static struct qcom_icc_node slv_sdcc_4 = {
1592 	.name = "slv_sdcc_4",
1593 	.id = MSM8996_SLAVE_SDCC_4,
1594 	.buswidth = 4,
1595 	.mas_rpm_id = -1,
1596 	.slv_rpm_id = 34
1597 };
1598 
1599 static struct qcom_icc_node slv_tsif = {
1600 	.name = "slv_tsif",
1601 	.id = MSM8996_SLAVE_TSIF,
1602 	.buswidth = 4,
1603 	.mas_rpm_id = -1,
1604 	.slv_rpm_id = 35
1605 };
1606 
1607 static struct qcom_icc_node slv_blsp_2 = {
1608 	.name = "slv_blsp_2",
1609 	.id = MSM8996_SLAVE_BLSP_2,
1610 	.buswidth = 4,
1611 	.mas_rpm_id = -1,
1612 	.slv_rpm_id = 37
1613 };
1614 
1615 static struct qcom_icc_node slv_sdcc_1 = {
1616 	.name = "slv_sdcc_1",
1617 	.id = MSM8996_SLAVE_SDCC_1,
1618 	.buswidth = 4,
1619 	.mas_rpm_id = -1,
1620 	.slv_rpm_id = 31
1621 };
1622 
1623 static struct qcom_icc_node slv_blsp_1 = {
1624 	.name = "slv_blsp_1",
1625 	.id = MSM8996_SLAVE_BLSP_1,
1626 	.buswidth = 4,
1627 	.mas_rpm_id = -1,
1628 	.slv_rpm_id = 39
1629 };
1630 
1631 static struct qcom_icc_node slv_pdm = {
1632 	.name = "slv_pdm",
1633 	.id = MSM8996_SLAVE_PDM,
1634 	.buswidth = 4,
1635 	.mas_rpm_id = -1,
1636 	.slv_rpm_id = 41
1637 };
1638 
1639 static struct qcom_icc_node slv_ahb2phy = {
1640 	.name = "slv_ahb2phy",
1641 	.id = MSM8996_SLAVE_AHB2PHY,
1642 	.buswidth = 4,
1643 	.mas_rpm_id = -1,
1644 	.slv_rpm_id = 153,
1645 	.qos.ap_owned = true,
1646 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1647 };
1648 
1649 static struct qcom_icc_node slv_hmss = {
1650 	.name = "slv_hmss",
1651 	.id = MSM8996_SLAVE_APPSS,
1652 	.buswidth = 16,
1653 	.mas_rpm_id = -1,
1654 	.slv_rpm_id = 20,
1655 	.qos.ap_owned = true,
1656 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1657 };
1658 
1659 static struct qcom_icc_node slv_lpass = {
1660 	.name = "slv_lpass",
1661 	.id = MSM8996_SLAVE_LPASS,
1662 	.buswidth = 16,
1663 	.mas_rpm_id = -1,
1664 	.slv_rpm_id = 21,
1665 	.qos.ap_owned = true,
1666 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1667 };
1668 
1669 static struct qcom_icc_node slv_usb3 = {
1670 	.name = "slv_usb3",
1671 	.id = MSM8996_SLAVE_USB3,
1672 	.buswidth = 16,
1673 	.mas_rpm_id = -1,
1674 	.slv_rpm_id = 22,
1675 	.qos.ap_owned = true,
1676 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1677 };
1678 
1679 static const u16 slv_snoc_bimc_links[] = {
1680 	MSM8996_MASTER_SNOC_BIMC
1681 };
1682 
1683 static struct qcom_icc_node slv_snoc_bimc = {
1684 	.name = "slv_snoc_bimc",
1685 	.id = MSM8996_SLAVE_SNOC_BIMC,
1686 	.buswidth = 32,
1687 	.mas_rpm_id = -1,
1688 	.slv_rpm_id = 24,
1689 	.num_links = ARRAY_SIZE(slv_snoc_bimc_links),
1690 	.links = slv_snoc_bimc_links
1691 };
1692 
1693 static const u16 slv_snoc_cnoc_links[] = {
1694 	MSM8996_MASTER_SNOC_CNOC
1695 };
1696 
1697 static struct qcom_icc_node slv_snoc_cnoc = {
1698 	.name = "slv_snoc_cnoc",
1699 	.id = MSM8996_SLAVE_SNOC_CNOC,
1700 	.buswidth = 16,
1701 	.mas_rpm_id = -1,
1702 	.slv_rpm_id = 25,
1703 	.num_links = ARRAY_SIZE(slv_snoc_cnoc_links),
1704 	.links = slv_snoc_cnoc_links
1705 };
1706 
1707 static struct qcom_icc_node slv_imem = {
1708 	.name = "slv_imem",
1709 	.id = MSM8996_SLAVE_OCIMEM,
1710 	.buswidth = 16,
1711 	.mas_rpm_id = -1,
1712 	.slv_rpm_id = 26
1713 };
1714 
1715 static struct qcom_icc_node slv_pimem = {
1716 	.name = "slv_pimem",
1717 	.id = MSM8996_SLAVE_PIMEM,
1718 	.buswidth = 16,
1719 	.mas_rpm_id = -1,
1720 	.slv_rpm_id = 166
1721 };
1722 
1723 static const u16 slv_snoc_vmem_links[] = {
1724 	MSM8996_MASTER_SNOC_VMEM
1725 };
1726 
1727 static struct qcom_icc_node slv_snoc_vmem = {
1728 	.name = "slv_snoc_vmem",
1729 	.id = MSM8996_SLAVE_SNOC_VMEM,
1730 	.buswidth = 16,
1731 	.mas_rpm_id = -1,
1732 	.slv_rpm_id = 140,
1733 	.qos.ap_owned = true,
1734 	.qos.qos_mode = NOC_QOS_MODE_INVALID,
1735 	.num_links = ARRAY_SIZE(slv_snoc_vmem_links),
1736 	.links = slv_snoc_vmem_links
1737 };
1738 
1739 static const u16 slv_snoc_pnoc_links[] = {
1740 	MSM8996_MASTER_SNOC_PNOC
1741 };
1742 
1743 static struct qcom_icc_node slv_snoc_pnoc = {
1744 	.name = "slv_snoc_pnoc",
1745 	.id = MSM8996_SLAVE_SNOC_PNOC,
1746 	.buswidth = 16,
1747 	.mas_rpm_id = -1,
1748 	.slv_rpm_id = 28,
1749 	.num_links = ARRAY_SIZE(slv_snoc_pnoc_links),
1750 	.links = slv_snoc_pnoc_links
1751 };
1752 
1753 static struct qcom_icc_node slv_qdss_stm = {
1754 	.name = "slv_qdss_stm",
1755 	.id = MSM8996_SLAVE_QDSS_STM,
1756 	.buswidth = 16,
1757 	.mas_rpm_id = -1,
1758 	.slv_rpm_id = 30
1759 };
1760 
1761 static struct qcom_icc_node slv_pcie_0 = {
1762 	.name = "slv_pcie_0",
1763 	.id = MSM8996_SLAVE_PCIE_0,
1764 	.buswidth = 16,
1765 	.mas_rpm_id = -1,
1766 	.slv_rpm_id = 84,
1767 	.qos.ap_owned = true,
1768 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1769 };
1770 
1771 static struct qcom_icc_node slv_pcie_1 = {
1772 	.name = "slv_pcie_1",
1773 	.id = MSM8996_SLAVE_PCIE_1,
1774 	.buswidth = 16,
1775 	.mas_rpm_id = -1,
1776 	.slv_rpm_id = 85,
1777 	.qos.ap_owned = true,
1778 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1779 };
1780 
1781 static struct qcom_icc_node slv_pcie_2 = {
1782 	.name = "slv_pcie_2",
1783 	.id = MSM8996_SLAVE_PCIE_2,
1784 	.buswidth = 16,
1785 	.mas_rpm_id = -1,
1786 	.slv_rpm_id = 164,
1787 	.qos.ap_owned = true,
1788 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1789 };
1790 
1791 static struct qcom_icc_node slv_srvc_snoc = {
1792 	.name = "slv_srvc_snoc",
1793 	.id = MSM8996_SLAVE_SERVICE_SNOC,
1794 	.buswidth = 16,
1795 	.mas_rpm_id = -1,
1796 	.slv_rpm_id = 29,
1797 	.qos.ap_owned = true,
1798 	.qos.qos_mode = NOC_QOS_MODE_INVALID
1799 };
1800 
1801 static struct qcom_icc_node * const a0noc_nodes[] = {
1802 	[MASTER_PCIE_0] = &mas_pcie_0,
1803 	[MASTER_PCIE_1] = &mas_pcie_1,
1804 	[MASTER_PCIE_2] = &mas_pcie_2
1805 };
1806 
1807 static const struct regmap_config msm8996_a0noc_regmap_config = {
1808 	.reg_bits	= 32,
1809 	.reg_stride	= 4,
1810 	.val_bits	= 32,
1811 	.max_register	= 0x6000,
1812 	.fast_io	= true
1813 };
1814 
1815 static const struct qcom_icc_desc msm8996_a0noc = {
1816 	.type = QCOM_ICC_NOC,
1817 	.nodes = a0noc_nodes,
1818 	.num_nodes = ARRAY_SIZE(a0noc_nodes),
1819 	.intf_clocks = a0noc_intf_clocks,
1820 	.num_intf_clocks = ARRAY_SIZE(a0noc_intf_clocks),
1821 	.regmap_cfg = &msm8996_a0noc_regmap_config
1822 };
1823 
1824 static struct qcom_icc_node * const a1noc_nodes[] = {
1825 	[MASTER_CNOC_A1NOC] = &mas_cnoc_a1noc,
1826 	[MASTER_CRYPTO_CORE0] = &mas_crypto_c0,
1827 	[MASTER_PNOC_A1NOC] = &mas_pnoc_a1noc
1828 };
1829 
1830 static const struct regmap_config msm8996_a1noc_regmap_config = {
1831 	.reg_bits	= 32,
1832 	.reg_stride	= 4,
1833 	.val_bits	= 32,
1834 	.max_register	= 0x5000,
1835 	.fast_io	= true
1836 };
1837 
1838 static const struct qcom_icc_desc msm8996_a1noc = {
1839 	.type = QCOM_ICC_NOC,
1840 	.nodes = a1noc_nodes,
1841 	.num_nodes = ARRAY_SIZE(a1noc_nodes),
1842 	.bus_clk_desc = &aggre1_branch_clk,
1843 	.regmap_cfg = &msm8996_a1noc_regmap_config
1844 };
1845 
1846 static struct qcom_icc_node * const a2noc_nodes[] = {
1847 	[MASTER_USB3] = &mas_usb3,
1848 	[MASTER_IPA] = &mas_ipa,
1849 	[MASTER_UFS] = &mas_ufs
1850 };
1851 
1852 static const struct regmap_config msm8996_a2noc_regmap_config = {
1853 	.reg_bits	= 32,
1854 	.reg_stride	= 4,
1855 	.val_bits	= 32,
1856 	.max_register	= 0x7000,
1857 	.fast_io	= true
1858 };
1859 
1860 static const struct qcom_icc_desc msm8996_a2noc = {
1861 	.type = QCOM_ICC_NOC,
1862 	.nodes = a2noc_nodes,
1863 	.num_nodes = ARRAY_SIZE(a2noc_nodes),
1864 	.bus_clk_desc = &aggre2_branch_clk,
1865 	.intf_clocks = a2noc_intf_clocks,
1866 	.num_intf_clocks = ARRAY_SIZE(a2noc_intf_clocks),
1867 	.regmap_cfg = &msm8996_a2noc_regmap_config
1868 };
1869 
1870 static struct qcom_icc_node * const bimc_nodes[] = {
1871 	[MASTER_AMPSS_M0] = &mas_apps_proc,
1872 	[MASTER_GRAPHICS_3D] = &mas_oxili,
1873 	[MASTER_MNOC_BIMC] = &mas_mnoc_bimc,
1874 	[MASTER_SNOC_BIMC] = &mas_snoc_bimc,
1875 	[SLAVE_EBI_CH0] = &slv_ebi,
1876 	[SLAVE_HMSS_L3] = &slv_hmss_l3,
1877 	[SLAVE_BIMC_SNOC_0] = &slv_bimc_snoc_0,
1878 	[SLAVE_BIMC_SNOC_1] = &slv_bimc_snoc_1
1879 };
1880 
1881 static const struct regmap_config msm8996_bimc_regmap_config = {
1882 	.reg_bits	= 32,
1883 	.reg_stride	= 4,
1884 	.val_bits	= 32,
1885 	.max_register	= 0x5a000,
1886 	.fast_io	= true
1887 };
1888 
1889 static const struct qcom_icc_desc msm8996_bimc = {
1890 	.type = QCOM_ICC_BIMC,
1891 	.nodes = bimc_nodes,
1892 	.num_nodes = ARRAY_SIZE(bimc_nodes),
1893 	.bus_clk_desc = &bimc_clk,
1894 	.regmap_cfg = &msm8996_bimc_regmap_config,
1895 	.ab_coeff = 154,
1896 };
1897 
1898 static struct qcom_icc_node * const cnoc_nodes[] = {
1899 	[MASTER_SNOC_CNOC] = &mas_snoc_cnoc,
1900 	[MASTER_QDSS_DAP] = &mas_qdss_dap,
1901 	[SLAVE_CNOC_A1NOC] = &slv_cnoc_a1noc,
1902 	[SLAVE_CLK_CTL] = &slv_clk_ctl,
1903 	[SLAVE_TCSR] = &slv_tcsr,
1904 	[SLAVE_TLMM] = &slv_tlmm,
1905 	[SLAVE_CRYPTO_0_CFG] = &slv_crypto0_cfg,
1906 	[SLAVE_MPM] = &slv_mpm,
1907 	[SLAVE_PIMEM_CFG] = &slv_pimem_cfg,
1908 	[SLAVE_IMEM_CFG] = &slv_imem_cfg,
1909 	[SLAVE_MESSAGE_RAM] = &slv_message_ram,
1910 	[SLAVE_BIMC_CFG] = &slv_bimc_cfg,
1911 	[SLAVE_PMIC_ARB] = &slv_pmic_arb,
1912 	[SLAVE_PRNG] = &slv_prng,
1913 	[SLAVE_DCC_CFG] = &slv_dcc_cfg,
1914 	[SLAVE_RBCPR_MX] = &slv_rbcpr_mx,
1915 	[SLAVE_QDSS_CFG] = &slv_qdss_cfg,
1916 	[SLAVE_RBCPR_CX] = &slv_rbcpr_cx,
1917 	[SLAVE_QDSS_RBCPR_APU] = &slv_cpu_apu_cfg,
1918 	[SLAVE_CNOC_MNOC_CFG] = &slv_cnoc_mnoc_cfg,
1919 	[SLAVE_SNOC_CFG] = &slv_snoc_cfg,
1920 	[SLAVE_SNOC_MPU_CFG] = &slv_snoc_mpu_cfg,
1921 	[SLAVE_EBI1_PHY_CFG] = &slv_ebi1_phy_cfg,
1922 	[SLAVE_A0NOC_CFG] = &slv_a0noc_cfg,
1923 	[SLAVE_PCIE_1_CFG] = &slv_pcie_1_cfg,
1924 	[SLAVE_PCIE_2_CFG] = &slv_pcie_2_cfg,
1925 	[SLAVE_PCIE_0_CFG] = &slv_pcie_0_cfg,
1926 	[SLAVE_PCIE20_AHB2PHY] = &slv_pcie20_ahb2phy,
1927 	[SLAVE_A0NOC_MPU_CFG] = &slv_a0noc_mpu_cfg,
1928 	[SLAVE_UFS_CFG] = &slv_ufs_cfg,
1929 	[SLAVE_A1NOC_CFG] = &slv_a1noc_cfg,
1930 	[SLAVE_A1NOC_MPU_CFG] = &slv_a1noc_mpu_cfg,
1931 	[SLAVE_A2NOC_CFG] = &slv_a2noc_cfg,
1932 	[SLAVE_A2NOC_MPU_CFG] = &slv_a2noc_mpu_cfg,
1933 	[SLAVE_SSC_CFG] = &slv_ssc_cfg,
1934 	[SLAVE_A0NOC_SMMU_CFG] = &slv_a0noc_smmu_cfg,
1935 	[SLAVE_A1NOC_SMMU_CFG] = &slv_a1noc_smmu_cfg,
1936 	[SLAVE_A2NOC_SMMU_CFG] = &slv_a2noc_smmu_cfg,
1937 	[SLAVE_LPASS_SMMU_CFG] = &slv_lpass_smmu_cfg,
1938 	[SLAVE_CNOC_MNOC_MMSS_CFG] = &slv_cnoc_mnoc_mmss_cfg
1939 };
1940 
1941 static const struct regmap_config msm8996_cnoc_regmap_config = {
1942 	.reg_bits	= 32,
1943 	.reg_stride	= 4,
1944 	.val_bits	= 32,
1945 	.max_register	= 0x1000,
1946 	.fast_io	= true
1947 };
1948 
1949 static const struct qcom_icc_desc msm8996_cnoc = {
1950 	.type = QCOM_ICC_NOC,
1951 	.nodes = cnoc_nodes,
1952 	.num_nodes = ARRAY_SIZE(cnoc_nodes),
1953 	.bus_clk_desc = &bus_2_clk,
1954 	.regmap_cfg = &msm8996_cnoc_regmap_config
1955 };
1956 
1957 static struct qcom_icc_node * const mnoc_nodes[] = {
1958 	[MASTER_CNOC_MNOC_CFG] = &mas_cnoc_mnoc_cfg,
1959 	[MASTER_CPP] = &mas_cpp,
1960 	[MASTER_JPEG] = &mas_jpeg,
1961 	[MASTER_MDP_PORT0] = &mas_mdp_p0,
1962 	[MASTER_MDP_PORT1] = &mas_mdp_p1,
1963 	[MASTER_ROTATOR] = &mas_rotator,
1964 	[MASTER_VIDEO_P0] = &mas_venus,
1965 	[MASTER_VFE] = &mas_vfe,
1966 	[MASTER_SNOC_VMEM] = &mas_snoc_vmem,
1967 	[MASTER_VIDEO_P0_OCMEM] = &mas_venus_vmem,
1968 	[MASTER_CNOC_MNOC_MMSS_CFG] = &mas_cnoc_mnoc_mmss_cfg,
1969 	[SLAVE_MNOC_BIMC] = &slv_mnoc_bimc,
1970 	[SLAVE_VMEM] = &slv_vmem,
1971 	[SLAVE_SERVICE_MNOC] = &slv_srvc_mnoc,
1972 	[SLAVE_MMAGIC_CFG] = &slv_mmagic_cfg,
1973 	[SLAVE_CPR_CFG] = &slv_cpr_cfg,
1974 	[SLAVE_MISC_CFG] = &slv_misc_cfg,
1975 	[SLAVE_VENUS_THROTTLE_CFG] = &slv_venus_throttle_cfg,
1976 	[SLAVE_VENUS_CFG] = &slv_venus_cfg,
1977 	[SLAVE_VMEM_CFG] = &slv_vmem_cfg,
1978 	[SLAVE_DSA_CFG] = &slv_dsa_cfg,
1979 	[SLAVE_MMSS_CLK_CFG] = &slv_mnoc_clocks_cfg,
1980 	[SLAVE_DSA_MPU_CFG] = &slv_dsa_mpu_cfg,
1981 	[SLAVE_MNOC_MPU_CFG] = &slv_mnoc_mpu_cfg,
1982 	[SLAVE_DISPLAY_CFG] = &slv_display_cfg,
1983 	[SLAVE_DISPLAY_THROTTLE_CFG] = &slv_display_throttle_cfg,
1984 	[SLAVE_CAMERA_CFG] = &slv_camera_cfg,
1985 	[SLAVE_CAMERA_THROTTLE_CFG] = &slv_camera_throttle_cfg,
1986 	[SLAVE_GRAPHICS_3D_CFG] = &slv_oxili_cfg,
1987 	[SLAVE_SMMU_MDP_CFG] = &slv_smmu_mdp_cfg,
1988 	[SLAVE_SMMU_ROT_CFG] = &slv_smmu_rot_cfg,
1989 	[SLAVE_SMMU_VENUS_CFG] = &slv_smmu_venus_cfg,
1990 	[SLAVE_SMMU_CPP_CFG] = &slv_smmu_cpp_cfg,
1991 	[SLAVE_SMMU_JPEG_CFG] = &slv_smmu_jpeg_cfg,
1992 	[SLAVE_SMMU_VFE_CFG] = &slv_smmu_vfe_cfg
1993 };
1994 
1995 static const struct regmap_config msm8996_mnoc_regmap_config = {
1996 	.reg_bits	= 32,
1997 	.reg_stride	= 4,
1998 	.val_bits	= 32,
1999 	.max_register	= 0x1c000,
2000 	.fast_io	= true
2001 };
2002 
2003 static const struct qcom_icc_desc msm8996_mnoc = {
2004 	.type = QCOM_ICC_NOC,
2005 	.nodes = mnoc_nodes,
2006 	.num_nodes = ARRAY_SIZE(mnoc_nodes),
2007 	.bus_clk_desc = &mmaxi_0_clk,
2008 	.intf_clocks = mm_intf_clocks,
2009 	.num_intf_clocks = ARRAY_SIZE(mm_intf_clocks),
2010 	.regmap_cfg = &msm8996_mnoc_regmap_config,
2011 	.ab_coeff = 154,
2012 };
2013 
2014 static struct qcom_icc_node * const pnoc_nodes[] = {
2015 	[MASTER_SNOC_PNOC] = &mas_snoc_pnoc,
2016 	[MASTER_SDCC_1] = &mas_sdcc_1,
2017 	[MASTER_SDCC_2] = &mas_sdcc_2,
2018 	[MASTER_SDCC_4] = &mas_sdcc_4,
2019 	[MASTER_USB_HS] = &mas_usb_hs,
2020 	[MASTER_BLSP_1] = &mas_blsp_1,
2021 	[MASTER_BLSP_2] = &mas_blsp_2,
2022 	[MASTER_TSIF] = &mas_tsif,
2023 	[SLAVE_PNOC_A1NOC] = &slv_pnoc_a1noc,
2024 	[SLAVE_USB_HS] = &slv_usb_hs,
2025 	[SLAVE_SDCC_2] = &slv_sdcc_2,
2026 	[SLAVE_SDCC_4] = &slv_sdcc_4,
2027 	[SLAVE_TSIF] = &slv_tsif,
2028 	[SLAVE_BLSP_2] = &slv_blsp_2,
2029 	[SLAVE_SDCC_1] = &slv_sdcc_1,
2030 	[SLAVE_BLSP_1] = &slv_blsp_1,
2031 	[SLAVE_PDM] = &slv_pdm,
2032 	[SLAVE_AHB2PHY] = &slv_ahb2phy
2033 };
2034 
2035 static const struct regmap_config msm8996_pnoc_regmap_config = {
2036 	.reg_bits	= 32,
2037 	.reg_stride	= 4,
2038 	.val_bits	= 32,
2039 	.max_register	= 0x3000,
2040 	.fast_io	= true
2041 };
2042 
2043 static const struct qcom_icc_desc msm8996_pnoc = {
2044 	.type = QCOM_ICC_NOC,
2045 	.nodes = pnoc_nodes,
2046 	.num_nodes = ARRAY_SIZE(pnoc_nodes),
2047 	.bus_clk_desc = &bus_0_clk,
2048 	.regmap_cfg = &msm8996_pnoc_regmap_config
2049 };
2050 
2051 static struct qcom_icc_node * const snoc_nodes[] = {
2052 	[MASTER_HMSS] = &mas_hmss,
2053 	[MASTER_QDSS_BAM] = &mas_qdss_bam,
2054 	[MASTER_SNOC_CFG] = &mas_snoc_cfg,
2055 	[MASTER_BIMC_SNOC_0] = &mas_bimc_snoc_0,
2056 	[MASTER_BIMC_SNOC_1] = &mas_bimc_snoc_1,
2057 	[MASTER_A0NOC_SNOC] = &mas_a0noc_snoc,
2058 	[MASTER_A1NOC_SNOC] = &mas_a1noc_snoc,
2059 	[MASTER_A2NOC_SNOC] = &mas_a2noc_snoc,
2060 	[MASTER_QDSS_ETR] = &mas_qdss_etr,
2061 	[SLAVE_A0NOC_SNOC] = &slv_a0noc_snoc,
2062 	[SLAVE_A1NOC_SNOC] = &slv_a1noc_snoc,
2063 	[SLAVE_A2NOC_SNOC] = &slv_a2noc_snoc,
2064 	[SLAVE_HMSS] = &slv_hmss,
2065 	[SLAVE_LPASS] = &slv_lpass,
2066 	[SLAVE_USB3] = &slv_usb3,
2067 	[SLAVE_SNOC_BIMC] = &slv_snoc_bimc,
2068 	[SLAVE_SNOC_CNOC] = &slv_snoc_cnoc,
2069 	[SLAVE_IMEM] = &slv_imem,
2070 	[SLAVE_PIMEM] = &slv_pimem,
2071 	[SLAVE_SNOC_VMEM] = &slv_snoc_vmem,
2072 	[SLAVE_SNOC_PNOC] = &slv_snoc_pnoc,
2073 	[SLAVE_QDSS_STM] = &slv_qdss_stm,
2074 	[SLAVE_PCIE_0] = &slv_pcie_0,
2075 	[SLAVE_PCIE_1] = &slv_pcie_1,
2076 	[SLAVE_PCIE_2] = &slv_pcie_2,
2077 	[SLAVE_SERVICE_SNOC] = &slv_srvc_snoc
2078 };
2079 
2080 static const struct regmap_config msm8996_snoc_regmap_config = {
2081 	.reg_bits	= 32,
2082 	.reg_stride	= 4,
2083 	.val_bits	= 32,
2084 	.max_register	= 0x20000,
2085 	.fast_io	= true
2086 };
2087 
2088 static const struct qcom_icc_desc msm8996_snoc = {
2089 	.type = QCOM_ICC_NOC,
2090 	.nodes = snoc_nodes,
2091 	.num_nodes = ARRAY_SIZE(snoc_nodes),
2092 	.bus_clk_desc = &bus_1_clk,
2093 	.regmap_cfg = &msm8996_snoc_regmap_config
2094 };
2095 
2096 static const struct of_device_id qnoc_of_match[] = {
2097 	{ .compatible = "qcom,msm8996-a0noc", .data = &msm8996_a0noc},
2098 	{ .compatible = "qcom,msm8996-a1noc", .data = &msm8996_a1noc},
2099 	{ .compatible = "qcom,msm8996-a2noc", .data = &msm8996_a2noc},
2100 	{ .compatible = "qcom,msm8996-bimc", .data = &msm8996_bimc},
2101 	{ .compatible = "qcom,msm8996-cnoc", .data = &msm8996_cnoc},
2102 	{ .compatible = "qcom,msm8996-mnoc", .data = &msm8996_mnoc},
2103 	{ .compatible = "qcom,msm8996-pnoc", .data = &msm8996_pnoc},
2104 	{ .compatible = "qcom,msm8996-snoc", .data = &msm8996_snoc},
2105 	{ }
2106 };
2107 MODULE_DEVICE_TABLE(of, qnoc_of_match);
2108 
2109 static struct platform_driver qnoc_driver = {
2110 	.probe = qnoc_probe,
2111 	.remove_new = qnoc_remove,
2112 	.driver = {
2113 		.name = "qnoc-msm8996",
2114 		.of_match_table = qnoc_of_match,
2115 		.sync_state = icc_sync_state,
2116 	}
2117 };
2118 static int __init qnoc_driver_init(void)
2119 {
2120 	return platform_driver_register(&qnoc_driver);
2121 }
2122 core_initcall(qnoc_driver_init);
2123 
2124 static void __exit qnoc_driver_exit(void)
2125 {
2126 	platform_driver_unregister(&qnoc_driver);
2127 }
2128 module_exit(qnoc_driver_exit);
2129 
2130 MODULE_AUTHOR("Yassine Oudjana <y.oudjana@protonmail.com>");
2131 MODULE_DESCRIPTION("Qualcomm MSM8996 NoC driver");
2132 MODULE_LICENSE("GPL v2");
2133