xref: /linux/drivers/memory/tegra/tegra194.c (revision 3d0fe49454652117522f60bfbefb978ba0e5300b)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Copyright (C) 2017-2021 NVIDIA CORPORATION.  All rights reserved.
4  */
5 
6 #include <soc/tegra/mc.h>
7 
8 #include <dt-bindings/memory/tegra194-mc.h>
9 
10 #include "mc.h"
11 
12 static const struct tegra_mc_client tegra194_mc_clients[] = {
13 	{
14 		.id = TEGRA194_MEMORY_CLIENT_PTCR,
15 		.name = "ptcr",
16 		.sid = TEGRA194_SID_PASSTHROUGH,
17 		.regs = {
18 			.sid = {
19 				.override = 0x000,
20 				.security = 0x004,
21 			},
22 		},
23 	}, {
24 		.id = TEGRA194_MEMORY_CLIENT_MIU7R,
25 		.name = "miu7r",
26 		.sid = TEGRA194_SID_MIU,
27 		.regs = {
28 			.sid = {
29 				.override = 0x008,
30 				.security = 0x00c,
31 			},
32 		},
33 	}, {
34 		.id = TEGRA194_MEMORY_CLIENT_MIU7W,
35 		.name = "miu7w",
36 		.sid = TEGRA194_SID_MIU,
37 		.regs = {
38 			.sid = {
39 				.override = 0x010,
40 				.security = 0x014,
41 			},
42 		},
43 	}, {
44 		.id = TEGRA194_MEMORY_CLIENT_HDAR,
45 		.name = "hdar",
46 		.sid = TEGRA194_SID_HDA,
47 		.regs = {
48 			.sid = {
49 				.override = 0x0a8,
50 				.security = 0x0ac,
51 			},
52 		},
53 	}, {
54 		.id = TEGRA194_MEMORY_CLIENT_HOST1XDMAR,
55 		.name = "host1xdmar",
56 		.sid = TEGRA194_SID_HOST1X,
57 		.regs = {
58 			.sid = {
59 				.override = 0x0b0,
60 				.security = 0x0b4,
61 			},
62 		},
63 	}, {
64 		.id = TEGRA194_MEMORY_CLIENT_NVENCSRD,
65 		.name = "nvencsrd",
66 		.sid = TEGRA194_SID_NVENC,
67 		.regs = {
68 			.sid = {
69 				.override = 0x0e0,
70 				.security = 0x0e4,
71 			},
72 		},
73 	}, {
74 		.id = TEGRA194_MEMORY_CLIENT_SATAR,
75 		.name = "satar",
76 		.sid = TEGRA194_SID_SATA,
77 		.regs = {
78 			.sid = {
79 				.override = 0x0f8,
80 				.security = 0x0fc,
81 			},
82 		},
83 	}, {
84 		.id = TEGRA194_MEMORY_CLIENT_MPCORER,
85 		.name = "mpcorer",
86 		.sid = TEGRA194_SID_PASSTHROUGH,
87 		.regs = {
88 			.sid = {
89 				.override = 0x138,
90 				.security = 0x13c,
91 			},
92 		},
93 	}, {
94 		.id = TEGRA194_MEMORY_CLIENT_NVENCSWR,
95 		.name = "nvencswr",
96 		.sid = TEGRA194_SID_NVENC,
97 		.regs = {
98 			.sid = {
99 				.override = 0x158,
100 				.security = 0x15c,
101 			},
102 		},
103 	}, {
104 		.id = TEGRA194_MEMORY_CLIENT_HDAW,
105 		.name = "hdaw",
106 		.sid = TEGRA194_SID_HDA,
107 		.regs = {
108 			.sid = {
109 				.override = 0x1a8,
110 				.security = 0x1ac,
111 			},
112 		},
113 	}, {
114 		.id = TEGRA194_MEMORY_CLIENT_MPCOREW,
115 		.name = "mpcorew",
116 		.sid = TEGRA194_SID_PASSTHROUGH,
117 		.regs = {
118 			.sid = {
119 				.override = 0x1c8,
120 				.security = 0x1cc,
121 			},
122 		},
123 	}, {
124 		.id = TEGRA194_MEMORY_CLIENT_SATAW,
125 		.name = "sataw",
126 		.sid = TEGRA194_SID_SATA,
127 		.regs = {
128 			.sid = {
129 				.override = 0x1e8,
130 				.security = 0x1ec,
131 			},
132 		},
133 	}, {
134 		.id = TEGRA194_MEMORY_CLIENT_ISPRA,
135 		.name = "ispra",
136 		.sid = TEGRA194_SID_ISP,
137 		.regs = {
138 			.sid = {
139 				.override = 0x220,
140 				.security = 0x224,
141 			},
142 		},
143 	}, {
144 		.id = TEGRA194_MEMORY_CLIENT_ISPFALR,
145 		.name = "ispfalr",
146 		.sid = TEGRA194_SID_ISP_FALCON,
147 		.regs = {
148 			.sid = {
149 				.override = 0x228,
150 				.security = 0x22c,
151 			},
152 		},
153 	}, {
154 		.id = TEGRA194_MEMORY_CLIENT_ISPWA,
155 		.name = "ispwa",
156 		.sid = TEGRA194_SID_ISP,
157 		.regs = {
158 			.sid = {
159 				.override = 0x230,
160 				.security = 0x234,
161 			},
162 		},
163 	}, {
164 		.id = TEGRA194_MEMORY_CLIENT_ISPWB,
165 		.name = "ispwb",
166 		.sid = TEGRA194_SID_ISP,
167 		.regs = {
168 			.sid = {
169 				.override = 0x238,
170 				.security = 0x23c,
171 			},
172 		},
173 	}, {
174 		.id = TEGRA194_MEMORY_CLIENT_XUSB_HOSTR,
175 		.name = "xusb_hostr",
176 		.sid = TEGRA194_SID_XUSB_HOST,
177 		.regs = {
178 			.sid = {
179 				.override = 0x250,
180 				.security = 0x254,
181 			},
182 		},
183 	}, {
184 		.id = TEGRA194_MEMORY_CLIENT_XUSB_HOSTW,
185 		.name = "xusb_hostw",
186 		.sid = TEGRA194_SID_XUSB_HOST,
187 		.regs = {
188 			.sid = {
189 				.override = 0x258,
190 				.security = 0x25c,
191 			},
192 		},
193 	}, {
194 		.id = TEGRA194_MEMORY_CLIENT_XUSB_DEVR,
195 		.name = "xusb_devr",
196 		.sid = TEGRA194_SID_XUSB_DEV,
197 		.regs = {
198 			.sid = {
199 				.override = 0x260,
200 				.security = 0x264,
201 			},
202 		},
203 	}, {
204 		.id = TEGRA194_MEMORY_CLIENT_XUSB_DEVW,
205 		.name = "xusb_devw",
206 		.sid = TEGRA194_SID_XUSB_DEV,
207 		.regs = {
208 			.sid = {
209 				.override = 0x268,
210 				.security = 0x26c,
211 			},
212 		},
213 	}, {
214 		.id = TEGRA194_MEMORY_CLIENT_SDMMCRA,
215 		.name = "sdmmcra",
216 		.sid = TEGRA194_SID_SDMMC1,
217 		.regs = {
218 			.sid = {
219 				.override = 0x300,
220 				.security = 0x304,
221 			},
222 		},
223 	}, {
224 		.id = TEGRA194_MEMORY_CLIENT_SDMMCR,
225 		.name = "sdmmcr",
226 		.sid = TEGRA194_SID_SDMMC3,
227 		.regs = {
228 			.sid = {
229 				.override = 0x310,
230 				.security = 0x314,
231 			},
232 		},
233 	}, {
234 		.id = TEGRA194_MEMORY_CLIENT_SDMMCRAB,
235 		.name = "sdmmcrab",
236 		.sid = TEGRA194_SID_SDMMC4,
237 		.regs = {
238 			.sid = {
239 				.override = 0x318,
240 				.security = 0x31c,
241 			},
242 		},
243 	}, {
244 		.id = TEGRA194_MEMORY_CLIENT_SDMMCWA,
245 		.name = "sdmmcwa",
246 		.sid = TEGRA194_SID_SDMMC1,
247 		.regs = {
248 			.sid = {
249 				.override = 0x320,
250 				.security = 0x324,
251 			},
252 		},
253 	}, {
254 		.id = TEGRA194_MEMORY_CLIENT_SDMMCW,
255 		.name = "sdmmcw",
256 		.sid = TEGRA194_SID_SDMMC3,
257 		.regs = {
258 			.sid = {
259 				.override = 0x330,
260 				.security = 0x334,
261 			},
262 		},
263 	}, {
264 		.id = TEGRA194_MEMORY_CLIENT_SDMMCWAB,
265 		.name = "sdmmcwab",
266 		.sid = TEGRA194_SID_SDMMC4,
267 		.regs = {
268 			.sid = {
269 				.override = 0x338,
270 				.security = 0x33c,
271 			},
272 		},
273 	}, {
274 		.id = TEGRA194_MEMORY_CLIENT_VICSRD,
275 		.name = "vicsrd",
276 		.sid = TEGRA194_SID_VIC,
277 		.regs = {
278 			.sid = {
279 				.override = 0x360,
280 				.security = 0x364,
281 			},
282 		},
283 	}, {
284 		.id = TEGRA194_MEMORY_CLIENT_VICSWR,
285 		.name = "vicswr",
286 		.sid = TEGRA194_SID_VIC,
287 		.regs = {
288 			.sid = {
289 				.override = 0x368,
290 				.security = 0x36c,
291 			},
292 		},
293 	}, {
294 		.id = TEGRA194_MEMORY_CLIENT_VIW,
295 		.name = "viw",
296 		.sid = TEGRA194_SID_VI,
297 		.regs = {
298 			.sid = {
299 				.override = 0x390,
300 				.security = 0x394,
301 			},
302 		},
303 	}, {
304 		.id = TEGRA194_MEMORY_CLIENT_NVDECSRD,
305 		.name = "nvdecsrd",
306 		.sid = TEGRA194_SID_NVDEC,
307 		.regs = {
308 			.sid = {
309 				.override = 0x3c0,
310 				.security = 0x3c4,
311 			},
312 		},
313 	}, {
314 		.id = TEGRA194_MEMORY_CLIENT_NVDECSWR,
315 		.name = "nvdecswr",
316 		.sid = TEGRA194_SID_NVDEC,
317 		.regs = {
318 			.sid = {
319 				.override = 0x3c8,
320 				.security = 0x3cc,
321 			},
322 		},
323 	}, {
324 		.id = TEGRA194_MEMORY_CLIENT_APER,
325 		.name = "aper",
326 		.sid = TEGRA194_SID_APE,
327 		.regs = {
328 			.sid = {
329 				.override = 0x3c0,
330 				.security = 0x3c4,
331 			},
332 		},
333 	}, {
334 		.id = TEGRA194_MEMORY_CLIENT_APEW,
335 		.name = "apew",
336 		.sid = TEGRA194_SID_APE,
337 		.regs = {
338 			.sid = {
339 				.override = 0x3d0,
340 				.security = 0x3d4,
341 			},
342 		},
343 	}, {
344 		.id = TEGRA194_MEMORY_CLIENT_NVJPGSRD,
345 		.name = "nvjpgsrd",
346 		.sid = TEGRA194_SID_NVJPG,
347 		.regs = {
348 			.sid = {
349 				.override = 0x3f0,
350 				.security = 0x3f4,
351 			},
352 		},
353 	}, {
354 		.id = TEGRA194_MEMORY_CLIENT_NVJPGSWR,
355 		.name = "nvjpgswr",
356 		.sid = TEGRA194_SID_NVJPG,
357 		.regs = {
358 			.sid = {
359 				.override = 0x3f0,
360 				.security = 0x3f4,
361 			},
362 		},
363 	}, {
364 		.name = "axiapr",
365 		.id = TEGRA194_MEMORY_CLIENT_AXIAPR,
366 		.sid = TEGRA194_SID_PASSTHROUGH,
367 		.regs = {
368 			.sid = {
369 				.override = 0x410,
370 				.security = 0x414,
371 			},
372 		},
373 	}, {
374 		.id = TEGRA194_MEMORY_CLIENT_AXIAPW,
375 		.name = "axiapw",
376 		.sid = TEGRA194_SID_PASSTHROUGH,
377 		.regs = {
378 			.sid = {
379 				.override = 0x418,
380 				.security = 0x41c,
381 			},
382 		},
383 	}, {
384 		.id = TEGRA194_MEMORY_CLIENT_ETRR,
385 		.name = "etrr",
386 		.sid = TEGRA194_SID_ETR,
387 		.regs = {
388 			.sid = {
389 				.override = 0x420,
390 				.security = 0x424,
391 			},
392 		},
393 	}, {
394 		.id = TEGRA194_MEMORY_CLIENT_ETRW,
395 		.name = "etrw",
396 		.sid = TEGRA194_SID_ETR,
397 		.regs = {
398 			.sid = {
399 				.override = 0x428,
400 				.security = 0x42c,
401 			},
402 		},
403 	}, {
404 		.id = TEGRA194_MEMORY_CLIENT_AXISR,
405 		.name = "axisr",
406 		.sid = TEGRA194_SID_PASSTHROUGH,
407 		.regs = {
408 			.sid = {
409 				.override = 0x460,
410 				.security = 0x464,
411 			},
412 		},
413 	}, {
414 		.id = TEGRA194_MEMORY_CLIENT_AXISW,
415 		.name = "axisw",
416 		.sid = TEGRA194_SID_PASSTHROUGH,
417 		.regs = {
418 			.sid = {
419 				.override = 0x468,
420 				.security = 0x46c,
421 			},
422 		},
423 	}, {
424 		.id = TEGRA194_MEMORY_CLIENT_EQOSR,
425 		.name = "eqosr",
426 		.sid = TEGRA194_SID_EQOS,
427 		.regs = {
428 			.sid = {
429 				.override = 0x470,
430 				.security = 0x474,
431 			},
432 		},
433 	}, {
434 		.name = "eqosw",
435 		.id = TEGRA194_MEMORY_CLIENT_EQOSW,
436 		.sid = TEGRA194_SID_EQOS,
437 		.regs = {
438 			.sid = {
439 				.override = 0x478,
440 				.security = 0x47c,
441 			},
442 		},
443 	}, {
444 		.id = TEGRA194_MEMORY_CLIENT_UFSHCR,
445 		.name = "ufshcr",
446 		.sid = TEGRA194_SID_UFSHC,
447 		.regs = {
448 			.sid = {
449 				.override = 0x480,
450 				.security = 0x484,
451 			},
452 		},
453 	}, {
454 		.id = TEGRA194_MEMORY_CLIENT_UFSHCW,
455 		.name = "ufshcw",
456 		.sid = TEGRA194_SID_UFSHC,
457 		.regs = {
458 			.sid = {
459 				.override = 0x488,
460 				.security = 0x48c,
461 			},
462 		},
463 	}, {
464 		.id = TEGRA194_MEMORY_CLIENT_NVDISPLAYR,
465 		.name = "nvdisplayr",
466 		.sid = TEGRA194_SID_NVDISPLAY,
467 		.regs = {
468 			.sid = {
469 				.override = 0x490,
470 				.security = 0x494,
471 			},
472 		},
473 	}, {
474 		.id = TEGRA194_MEMORY_CLIENT_BPMPR,
475 		.name = "bpmpr",
476 		.sid = TEGRA194_SID_BPMP,
477 		.regs = {
478 			.sid = {
479 				.override = 0x498,
480 				.security = 0x49c,
481 			},
482 		},
483 	}, {
484 		.id = TEGRA194_MEMORY_CLIENT_BPMPW,
485 		.name = "bpmpw",
486 		.sid = TEGRA194_SID_BPMP,
487 		.regs = {
488 			.sid = {
489 				.override = 0x4a0,
490 				.security = 0x4a4,
491 			},
492 		},
493 	}, {
494 		.id = TEGRA194_MEMORY_CLIENT_BPMPDMAR,
495 		.name = "bpmpdmar",
496 		.sid = TEGRA194_SID_BPMP,
497 		.regs = {
498 			.sid = {
499 				.override = 0x4a8,
500 				.security = 0x4ac,
501 			},
502 		},
503 	}, {
504 		.id = TEGRA194_MEMORY_CLIENT_BPMPDMAW,
505 		.name = "bpmpdmaw",
506 		.sid = TEGRA194_SID_BPMP,
507 		.regs = {
508 			.sid = {
509 				.override = 0x4b0,
510 				.security = 0x4b4,
511 			},
512 		},
513 	}, {
514 		.id = TEGRA194_MEMORY_CLIENT_AONR,
515 		.name = "aonr",
516 		.sid = TEGRA194_SID_AON,
517 		.regs = {
518 			.sid = {
519 				.override = 0x4b8,
520 				.security = 0x4bc,
521 			},
522 		},
523 	}, {
524 		.id = TEGRA194_MEMORY_CLIENT_AONW,
525 		.name = "aonw",
526 		.sid = TEGRA194_SID_AON,
527 		.regs = {
528 			.sid = {
529 				.override = 0x4c0,
530 				.security = 0x4c4,
531 			},
532 		},
533 	}, {
534 		.id = TEGRA194_MEMORY_CLIENT_AONDMAR,
535 		.name = "aondmar",
536 		.sid = TEGRA194_SID_AON,
537 		.regs = {
538 			.sid = {
539 				.override = 0x4c8,
540 				.security = 0x4cc,
541 			},
542 		},
543 	}, {
544 		.id = TEGRA194_MEMORY_CLIENT_AONDMAW,
545 		.name = "aondmaw",
546 		.sid = TEGRA194_SID_AON,
547 		.regs = {
548 			.sid = {
549 				.override = 0x4d0,
550 				.security = 0x4d4,
551 			},
552 		},
553 	}, {
554 		.id = TEGRA194_MEMORY_CLIENT_SCER,
555 		.name = "scer",
556 		.sid = TEGRA194_SID_SCE,
557 		.regs = {
558 			.sid = {
559 				.override = 0x4d8,
560 				.security = 0x4dc,
561 			},
562 		},
563 	}, {
564 		.id = TEGRA194_MEMORY_CLIENT_SCEW,
565 		.name = "scew",
566 		.sid = TEGRA194_SID_SCE,
567 		.regs = {
568 			.sid = {
569 				.override = 0x4e0,
570 				.security = 0x4e4,
571 			},
572 		},
573 	}, {
574 		.id = TEGRA194_MEMORY_CLIENT_SCEDMAR,
575 		.name = "scedmar",
576 		.sid = TEGRA194_SID_SCE,
577 		.regs = {
578 			.sid = {
579 				.override = 0x4e8,
580 				.security = 0x4ec,
581 			},
582 		},
583 	}, {
584 		.id = TEGRA194_MEMORY_CLIENT_SCEDMAW,
585 		.name = "scedmaw",
586 		.sid = TEGRA194_SID_SCE,
587 		.regs = {
588 			.sid = {
589 				.override = 0x4f0,
590 				.security = 0x4f4,
591 			},
592 		},
593 	}, {
594 		.id = TEGRA194_MEMORY_CLIENT_APEDMAR,
595 		.name = "apedmar",
596 		.sid = TEGRA194_SID_APE,
597 		.regs = {
598 			.sid = {
599 				.override = 0x4f8,
600 				.security = 0x4fc,
601 			},
602 		},
603 	}, {
604 		.id = TEGRA194_MEMORY_CLIENT_APEDMAW,
605 		.name = "apedmaw",
606 		.sid = TEGRA194_SID_APE,
607 		.regs = {
608 			.sid = {
609 				.override = 0x500,
610 				.security = 0x504,
611 			},
612 		},
613 	}, {
614 		.id = TEGRA194_MEMORY_CLIENT_NVDISPLAYR1,
615 		.name = "nvdisplayr1",
616 		.sid = TEGRA194_SID_NVDISPLAY,
617 		.regs = {
618 			.sid = {
619 				.override = 0x508,
620 				.security = 0x50c,
621 			},
622 		},
623 	}, {
624 		.id = TEGRA194_MEMORY_CLIENT_VICSRD1,
625 		.name = "vicsrd1",
626 		.sid = TEGRA194_SID_VIC,
627 		.regs = {
628 			.sid = {
629 				.override = 0x510,
630 				.security = 0x514,
631 			},
632 		},
633 	}, {
634 		.id = TEGRA194_MEMORY_CLIENT_NVDECSRD1,
635 		.name = "nvdecsrd1",
636 		.sid = TEGRA194_SID_NVDEC,
637 		.regs = {
638 			.sid = {
639 				.override = 0x518,
640 				.security = 0x51c,
641 			},
642 		},
643 	}, {
644 		.id = TEGRA194_MEMORY_CLIENT_MIU0R,
645 		.name = "miu0r",
646 		.sid = TEGRA194_SID_MIU,
647 		.regs = {
648 			.sid = {
649 				.override = 0x530,
650 				.security = 0x534,
651 			},
652 		},
653 	}, {
654 		.name = "miu0w",
655 		.id = TEGRA194_MEMORY_CLIENT_MIU0W,
656 		.sid = TEGRA194_SID_MIU,
657 		.regs = {
658 			.sid = {
659 				.override = 0x538,
660 				.security = 0x53c,
661 			},
662 		},
663 	}, {
664 		.id = TEGRA194_MEMORY_CLIENT_MIU1R,
665 		.name = "miu1r",
666 		.sid = TEGRA194_SID_MIU,
667 		.regs = {
668 			.sid = {
669 				.override = 0x540,
670 				.security = 0x544,
671 			},
672 		},
673 	}, {
674 		.id = TEGRA194_MEMORY_CLIENT_MIU1W,
675 		.name = "miu1w",
676 		.sid = TEGRA194_SID_MIU,
677 		.regs = {
678 			.sid = {
679 				.override = 0x548,
680 				.security = 0x54c,
681 			},
682 		},
683 	}, {
684 		.id = TEGRA194_MEMORY_CLIENT_MIU2R,
685 		.name = "miu2r",
686 		.sid = TEGRA194_SID_MIU,
687 		.regs = {
688 			.sid = {
689 				.override = 0x570,
690 				.security = 0x574,
691 			},
692 		},
693 	}, {
694 		.id = TEGRA194_MEMORY_CLIENT_MIU2W,
695 		.name = "miu2w",
696 		.sid = TEGRA194_SID_MIU,
697 		.regs = {
698 			.sid = {
699 				.override = 0x578,
700 				.security = 0x57c,
701 			},
702 		},
703 	}, {
704 		.id = TEGRA194_MEMORY_CLIENT_MIU3R,
705 		.name = "miu3r",
706 		.sid = TEGRA194_SID_MIU,
707 		.regs = {
708 			.sid = {
709 				.override = 0x580,
710 				.security = 0x584,
711 			},
712 		},
713 	}, {
714 		.id = TEGRA194_MEMORY_CLIENT_MIU3W,
715 		.name = "miu3w",
716 		.sid = TEGRA194_SID_MIU,
717 		.regs = {
718 			.sid = {
719 				.override = 0x588,
720 				.security = 0x58c,
721 			},
722 		},
723 	}, {
724 		.id = TEGRA194_MEMORY_CLIENT_MIU4R,
725 		.name = "miu4r",
726 		.sid = TEGRA194_SID_MIU,
727 		.regs = {
728 			.sid = {
729 				.override = 0x590,
730 				.security = 0x594,
731 			},
732 		},
733 	}, {
734 		.id = TEGRA194_MEMORY_CLIENT_MIU4W,
735 		.name = "miu4w",
736 		.sid = TEGRA194_SID_MIU,
737 		.regs = {
738 			.sid = {
739 				.override = 0x598,
740 				.security = 0x59c,
741 			},
742 		},
743 	}, {
744 		.id = TEGRA194_MEMORY_CLIENT_DPMUR,
745 		.name = "dpmur",
746 		.sid = TEGRA194_SID_PASSTHROUGH,
747 		.regs = {
748 			.sid = {
749 				.override = 0x598,
750 				.security = 0x59c,
751 			},
752 		},
753 	}, {
754 		.id = TEGRA194_MEMORY_CLIENT_VIFALR,
755 		.name = "vifalr",
756 		.sid = TEGRA194_SID_VI_FALCON,
757 		.regs = {
758 			.sid = {
759 				.override = 0x5e0,
760 				.security = 0x5e4,
761 			},
762 		},
763 	}, {
764 		.id = TEGRA194_MEMORY_CLIENT_VIFALW,
765 		.name = "vifalw",
766 		.sid = TEGRA194_SID_VI_FALCON,
767 		.regs = {
768 			.sid = {
769 				.override = 0x5e8,
770 				.security = 0x5ec,
771 			},
772 		},
773 	}, {
774 		.id = TEGRA194_MEMORY_CLIENT_DLA0RDA,
775 		.name = "dla0rda",
776 		.sid = TEGRA194_SID_NVDLA0,
777 		.regs = {
778 			.sid = {
779 				.override = 0x5f0,
780 				.security = 0x5f4,
781 			},
782 		},
783 	}, {
784 		.id = TEGRA194_MEMORY_CLIENT_DLA0FALRDB,
785 		.name = "dla0falrdb",
786 		.sid = TEGRA194_SID_NVDLA0,
787 		.regs = {
788 			.sid = {
789 				.override = 0x5f8,
790 				.security = 0x5fc,
791 			},
792 		},
793 	}, {
794 		.id = TEGRA194_MEMORY_CLIENT_DLA0WRA,
795 		.name = "dla0wra",
796 		.sid = TEGRA194_SID_NVDLA0,
797 		.regs = {
798 			.sid = {
799 				.override = 0x600,
800 				.security = 0x604,
801 			},
802 		},
803 	}, {
804 		.id = TEGRA194_MEMORY_CLIENT_DLA0FALWRB,
805 		.name = "dla0falwrb",
806 		.sid = TEGRA194_SID_NVDLA0,
807 		.regs = {
808 			.sid = {
809 				.override = 0x608,
810 				.security = 0x60c,
811 			},
812 		},
813 	}, {
814 		.id = TEGRA194_MEMORY_CLIENT_DLA1RDA,
815 		.name = "dla1rda",
816 		.sid = TEGRA194_SID_NVDLA1,
817 		.regs = {
818 			.sid = {
819 				.override = 0x610,
820 				.security = 0x614,
821 			},
822 		},
823 	}, {
824 		.id = TEGRA194_MEMORY_CLIENT_DLA1FALRDB,
825 		.name = "dla1falrdb",
826 		.sid = TEGRA194_SID_NVDLA1,
827 		.regs = {
828 			.sid = {
829 				.override = 0x618,
830 				.security = 0x61c,
831 			},
832 		},
833 	}, {
834 		.id = TEGRA194_MEMORY_CLIENT_DLA1WRA,
835 		.name = "dla1wra",
836 		.sid = TEGRA194_SID_NVDLA1,
837 		.regs = {
838 			.sid = {
839 				.override = 0x620,
840 				.security = 0x624,
841 			},
842 		},
843 	}, {
844 		.id = TEGRA194_MEMORY_CLIENT_DLA1FALWRB,
845 		.name = "dla1falwrb",
846 		.sid = TEGRA194_SID_NVDLA1,
847 		.regs = {
848 			.sid = {
849 				.override = 0x628,
850 				.security = 0x62c,
851 			},
852 		},
853 	}, {
854 		.id = TEGRA194_MEMORY_CLIENT_PVA0RDA,
855 		.name = "pva0rda",
856 		.sid = TEGRA194_SID_PVA0,
857 		.regs = {
858 			.sid = {
859 				.override = 0x630,
860 				.security = 0x634,
861 			},
862 		},
863 	}, {
864 		.id = TEGRA194_MEMORY_CLIENT_PVA0RDB,
865 		.name = "pva0rdb",
866 		.sid = TEGRA194_SID_PVA0,
867 		.regs = {
868 			.sid = {
869 				.override = 0x638,
870 				.security = 0x63c,
871 			},
872 		},
873 	}, {
874 		.id = TEGRA194_MEMORY_CLIENT_PVA0RDC,
875 		.name = "pva0rdc",
876 		.sid = TEGRA194_SID_PVA0,
877 		.regs = {
878 			.sid = {
879 				.override = 0x640,
880 				.security = 0x644,
881 			},
882 		},
883 	}, {
884 		.id = TEGRA194_MEMORY_CLIENT_PVA0WRA,
885 		.name = "pva0wra",
886 		.sid = TEGRA194_SID_PVA0,
887 		.regs = {
888 			.sid = {
889 				.override = 0x648,
890 				.security = 0x64c,
891 			},
892 		},
893 	}, {
894 		.id = TEGRA194_MEMORY_CLIENT_PVA0WRB,
895 		.name = "pva0wrb",
896 		.sid = TEGRA194_SID_PVA0,
897 		.regs = {
898 			.sid = {
899 				.override = 0x650,
900 				.security = 0x654,
901 			},
902 		},
903 	}, {
904 		.id = TEGRA194_MEMORY_CLIENT_PVA0WRC,
905 		.name = "pva0wrc",
906 		.sid = TEGRA194_SID_PVA0,
907 		.regs = {
908 			.sid = {
909 				.override = 0x658,
910 				.security = 0x65c,
911 			},
912 		},
913 	}, {
914 		.id = TEGRA194_MEMORY_CLIENT_PVA1RDA,
915 		.name = "pva1rda",
916 		.sid = TEGRA194_SID_PVA1,
917 		.regs = {
918 			.sid = {
919 				.override = 0x660,
920 				.security = 0x664,
921 			},
922 		},
923 	}, {
924 		.id = TEGRA194_MEMORY_CLIENT_PVA1RDB,
925 		.name = "pva1rdb",
926 		.sid = TEGRA194_SID_PVA1,
927 		.regs = {
928 			.sid = {
929 				.override = 0x668,
930 				.security = 0x66c,
931 			},
932 		},
933 	}, {
934 		.id = TEGRA194_MEMORY_CLIENT_PVA1RDC,
935 		.name = "pva1rdc",
936 		.sid = TEGRA194_SID_PVA1,
937 		.regs = {
938 			.sid = {
939 				.override = 0x670,
940 				.security = 0x674,
941 			},
942 		},
943 	}, {
944 		.id = TEGRA194_MEMORY_CLIENT_PVA1WRA,
945 		.name = "pva1wra",
946 		.sid = TEGRA194_SID_PVA1,
947 		.regs = {
948 			.sid = {
949 				.override = 0x678,
950 				.security = 0x67c,
951 			},
952 		},
953 	}, {
954 		.id = TEGRA194_MEMORY_CLIENT_PVA1WRB,
955 		.name = "pva1wrb",
956 		.sid = TEGRA194_SID_PVA1,
957 		.regs = {
958 			.sid = {
959 				.override = 0x680,
960 				.security = 0x684,
961 			},
962 		},
963 	}, {
964 		.id = TEGRA194_MEMORY_CLIENT_PVA1WRC,
965 		.name = "pva1wrc",
966 		.sid = TEGRA194_SID_PVA1,
967 		.regs = {
968 			.sid = {
969 				.override = 0x688,
970 				.security = 0x68c,
971 			},
972 		},
973 	}, {
974 		.id = TEGRA194_MEMORY_CLIENT_RCER,
975 		.name = "rcer",
976 		.sid = TEGRA194_SID_RCE,
977 		.regs = {
978 			.sid = {
979 				.override = 0x690,
980 				.security = 0x694,
981 			},
982 		},
983 	}, {
984 		.id = TEGRA194_MEMORY_CLIENT_RCEW,
985 		.name = "rcew",
986 		.sid = TEGRA194_SID_RCE,
987 		.regs = {
988 			.sid = {
989 				.override = 0x698,
990 				.security = 0x69c,
991 			},
992 		},
993 	}, {
994 		.id = TEGRA194_MEMORY_CLIENT_RCEDMAR,
995 		.name = "rcedmar",
996 		.sid = TEGRA194_SID_RCE,
997 		.regs = {
998 			.sid = {
999 				.override = 0x6a0,
1000 				.security = 0x6a4,
1001 			},
1002 		},
1003 	}, {
1004 		.id = TEGRA194_MEMORY_CLIENT_RCEDMAW,
1005 		.name = "rcedmaw",
1006 		.sid = TEGRA194_SID_RCE,
1007 		.regs = {
1008 			.sid = {
1009 				.override = 0x6a8,
1010 				.security = 0x6ac,
1011 			},
1012 		},
1013 	}, {
1014 		.id = TEGRA194_MEMORY_CLIENT_NVENC1SRD,
1015 		.name = "nvenc1srd",
1016 		.sid = TEGRA194_SID_NVENC1,
1017 		.regs = {
1018 			.sid = {
1019 				.override = 0x6b0,
1020 				.security = 0x6b4,
1021 			},
1022 		},
1023 	}, {
1024 		.id = TEGRA194_MEMORY_CLIENT_NVENC1SWR,
1025 		.name = "nvenc1swr",
1026 		.sid = TEGRA194_SID_NVENC1,
1027 		.regs = {
1028 			.sid = {
1029 				.override = 0x6b8,
1030 				.security = 0x6bc,
1031 			},
1032 		},
1033 	}, {
1034 		.id = TEGRA194_MEMORY_CLIENT_PCIE0R,
1035 		.name = "pcie0r",
1036 		.sid = TEGRA194_SID_PCIE0,
1037 		.regs = {
1038 			.sid = {
1039 				.override = 0x6c0,
1040 				.security = 0x6c4,
1041 			},
1042 		},
1043 	}, {
1044 		.id = TEGRA194_MEMORY_CLIENT_PCIE0W,
1045 		.name = "pcie0w",
1046 		.sid = TEGRA194_SID_PCIE0,
1047 		.regs = {
1048 			.sid = {
1049 				.override = 0x6c8,
1050 				.security = 0x6cc,
1051 			},
1052 		},
1053 	}, {
1054 		.id = TEGRA194_MEMORY_CLIENT_PCIE1R,
1055 		.name = "pcie1r",
1056 		.sid = TEGRA194_SID_PCIE1,
1057 		.regs = {
1058 			.sid = {
1059 				.override = 0x6d0,
1060 				.security = 0x6d4,
1061 			},
1062 		},
1063 	}, {
1064 		.id = TEGRA194_MEMORY_CLIENT_PCIE1W,
1065 		.name = "pcie1w",
1066 		.sid = TEGRA194_SID_PCIE1,
1067 		.regs = {
1068 			.sid = {
1069 				.override = 0x6d8,
1070 				.security = 0x6dc,
1071 			},
1072 		},
1073 	}, {
1074 		.id = TEGRA194_MEMORY_CLIENT_PCIE2AR,
1075 		.name = "pcie2ar",
1076 		.sid = TEGRA194_SID_PCIE2,
1077 		.regs = {
1078 			.sid = {
1079 				.override = 0x6e0,
1080 				.security = 0x6e4,
1081 			},
1082 		},
1083 	}, {
1084 		.id = TEGRA194_MEMORY_CLIENT_PCIE2AW,
1085 		.name = "pcie2aw",
1086 		.sid = TEGRA194_SID_PCIE2,
1087 		.regs = {
1088 			.sid = {
1089 				.override = 0x6e8,
1090 				.security = 0x6ec,
1091 			},
1092 		},
1093 	}, {
1094 		.id = TEGRA194_MEMORY_CLIENT_PCIE3R,
1095 		.name = "pcie3r",
1096 		.sid = TEGRA194_SID_PCIE3,
1097 		.regs = {
1098 			.sid = {
1099 				.override = 0x6f0,
1100 				.security = 0x6f4,
1101 			},
1102 		},
1103 	}, {
1104 		.id = TEGRA194_MEMORY_CLIENT_PCIE3W,
1105 		.name = "pcie3w",
1106 		.sid = TEGRA194_SID_PCIE3,
1107 		.regs = {
1108 			.sid = {
1109 				.override = 0x6f8,
1110 				.security = 0x6fc,
1111 			},
1112 		},
1113 	}, {
1114 		.id = TEGRA194_MEMORY_CLIENT_PCIE4R,
1115 		.name = "pcie4r",
1116 		.sid = TEGRA194_SID_PCIE4,
1117 		.regs = {
1118 			.sid = {
1119 				.override = 0x700,
1120 				.security = 0x704,
1121 			},
1122 		},
1123 	}, {
1124 		.id = TEGRA194_MEMORY_CLIENT_PCIE4W,
1125 		.name = "pcie4w",
1126 		.sid = TEGRA194_SID_PCIE4,
1127 		.regs = {
1128 			.sid = {
1129 				.override = 0x708,
1130 				.security = 0x70c,
1131 			},
1132 		},
1133 	}, {
1134 		.id = TEGRA194_MEMORY_CLIENT_PCIE5R,
1135 		.name = "pcie5r",
1136 		.sid = TEGRA194_SID_PCIE5,
1137 		.regs = {
1138 			.sid = {
1139 				.override = 0x710,
1140 				.security = 0x714,
1141 			},
1142 		},
1143 	}, {
1144 		.id = TEGRA194_MEMORY_CLIENT_PCIE5W,
1145 		.name = "pcie5w",
1146 		.sid = TEGRA194_SID_PCIE5,
1147 		.regs = {
1148 			.sid = {
1149 				.override = 0x718,
1150 				.security = 0x71c,
1151 			},
1152 		},
1153 	}, {
1154 		.id = TEGRA194_MEMORY_CLIENT_ISPFALW,
1155 		.name = "ispfalw",
1156 		.sid = TEGRA194_SID_ISP_FALCON,
1157 		.regs = {
1158 			.sid = {
1159 				.override = 0x720,
1160 				.security = 0x724,
1161 			},
1162 		},
1163 	}, {
1164 		.id = TEGRA194_MEMORY_CLIENT_DLA0RDA1,
1165 		.name = "dla0rda1",
1166 		.sid = TEGRA194_SID_NVDLA0,
1167 		.regs = {
1168 			.sid = {
1169 				.override = 0x748,
1170 				.security = 0x74c,
1171 			},
1172 		},
1173 	}, {
1174 		.id = TEGRA194_MEMORY_CLIENT_DLA1RDA1,
1175 		.name = "dla1rda1",
1176 		.sid = TEGRA194_SID_NVDLA1,
1177 		.regs = {
1178 			.sid = {
1179 				.override = 0x750,
1180 				.security = 0x754,
1181 			},
1182 		},
1183 	}, {
1184 		.id = TEGRA194_MEMORY_CLIENT_PVA0RDA1,
1185 		.name = "pva0rda1",
1186 		.sid = TEGRA194_SID_PVA0,
1187 		.regs = {
1188 			.sid = {
1189 				.override = 0x758,
1190 				.security = 0x75c,
1191 			},
1192 		},
1193 	}, {
1194 		.id = TEGRA194_MEMORY_CLIENT_PVA0RDB1,
1195 		.name = "pva0rdb1",
1196 		.sid = TEGRA194_SID_PVA0,
1197 		.regs = {
1198 			.sid = {
1199 				.override = 0x760,
1200 				.security = 0x764,
1201 			},
1202 		},
1203 	}, {
1204 		.id = TEGRA194_MEMORY_CLIENT_PVA1RDA1,
1205 		.name = "pva1rda1",
1206 		.sid = TEGRA194_SID_PVA1,
1207 		.regs = {
1208 			.sid = {
1209 				.override = 0x768,
1210 				.security = 0x76c,
1211 			},
1212 		},
1213 	}, {
1214 		.id = TEGRA194_MEMORY_CLIENT_PVA1RDB1,
1215 		.name = "pva1rdb1",
1216 		.sid = TEGRA194_SID_PVA1,
1217 		.regs = {
1218 			.sid = {
1219 				.override = 0x770,
1220 				.security = 0x774,
1221 			},
1222 		},
1223 	}, {
1224 		.id = TEGRA194_MEMORY_CLIENT_PCIE5R1,
1225 		.name = "pcie5r1",
1226 		.sid = TEGRA194_SID_PCIE5,
1227 		.regs = {
1228 			.sid = {
1229 				.override = 0x778,
1230 				.security = 0x77c,
1231 			},
1232 		},
1233 	}, {
1234 		.id = TEGRA194_MEMORY_CLIENT_NVENCSRD1,
1235 		.name = "nvencsrd1",
1236 		.sid = TEGRA194_SID_NVENC,
1237 		.regs = {
1238 			.sid = {
1239 				.override = 0x780,
1240 				.security = 0x784,
1241 			},
1242 		},
1243 	}, {
1244 		.id = TEGRA194_MEMORY_CLIENT_NVENC1SRD1,
1245 		.name = "nvenc1srd1",
1246 		.sid = TEGRA194_SID_NVENC1,
1247 		.regs = {
1248 			.sid = {
1249 				.override = 0x788,
1250 				.security = 0x78c,
1251 			},
1252 		},
1253 	}, {
1254 		.id = TEGRA194_MEMORY_CLIENT_ISPRA1,
1255 		.name = "ispra1",
1256 		.sid = TEGRA194_SID_ISP,
1257 		.regs = {
1258 			.sid = {
1259 				.override = 0x790,
1260 				.security = 0x794,
1261 			},
1262 		},
1263 	}, {
1264 		.id = TEGRA194_MEMORY_CLIENT_PCIE0R1,
1265 		.name = "pcie0r1",
1266 		.sid = TEGRA194_SID_PCIE0,
1267 		.regs = {
1268 			.sid = {
1269 				.override = 0x798,
1270 				.security = 0x79c,
1271 			},
1272 		},
1273 	}, {
1274 		.id = TEGRA194_MEMORY_CLIENT_NVDEC1SRD,
1275 		.name = "nvdec1srd",
1276 		.sid = TEGRA194_SID_NVDEC1,
1277 		.regs = {
1278 			.sid = {
1279 				.override = 0x7c8,
1280 				.security = 0x7cc,
1281 			},
1282 		},
1283 	}, {
1284 		.id = TEGRA194_MEMORY_CLIENT_NVDEC1SRD1,
1285 		.name = "nvdec1srd1",
1286 		.sid = TEGRA194_SID_NVDEC1,
1287 		.regs = {
1288 			.sid = {
1289 				.override = 0x7d0,
1290 				.security = 0x7d4,
1291 			},
1292 		},
1293 	}, {
1294 		.id = TEGRA194_MEMORY_CLIENT_NVDEC1SWR,
1295 		.name = "nvdec1swr",
1296 		.sid = TEGRA194_SID_NVDEC1,
1297 		.regs = {
1298 			.sid = {
1299 				.override = 0x7d8,
1300 				.security = 0x7dc,
1301 			},
1302 		},
1303 	}, {
1304 		.id = TEGRA194_MEMORY_CLIENT_MIU5R,
1305 		.name = "miu5r",
1306 		.sid = TEGRA194_SID_MIU,
1307 		.regs = {
1308 			.sid = {
1309 				.override = 0x7e0,
1310 				.security = 0x7e4,
1311 			},
1312 		},
1313 	}, {
1314 		.id = TEGRA194_MEMORY_CLIENT_MIU5W,
1315 		.name = "miu5w",
1316 		.sid = TEGRA194_SID_MIU,
1317 		.regs = {
1318 			.sid = {
1319 				.override = 0x7e8,
1320 				.security = 0x7ec,
1321 			},
1322 		},
1323 	}, {
1324 		.id = TEGRA194_MEMORY_CLIENT_MIU6R,
1325 		.name = "miu6r",
1326 		.sid = TEGRA194_SID_MIU,
1327 		.regs = {
1328 			.sid = {
1329 				.override = 0x7f0,
1330 				.security = 0x7f4,
1331 			},
1332 		},
1333 	}, {
1334 		.id = TEGRA194_MEMORY_CLIENT_MIU6W,
1335 		.name = "miu6w",
1336 		.sid = TEGRA194_SID_MIU,
1337 		.regs = {
1338 			.sid = {
1339 				.override = 0x7f8,
1340 				.security = 0x7fc,
1341 			},
1342 		},
1343 	},
1344 };
1345 
1346 const struct tegra_mc_soc tegra194_mc_soc = {
1347 	.num_clients = ARRAY_SIZE(tegra194_mc_clients),
1348 	.clients = tegra194_mc_clients,
1349 	.num_address_bits = 40,
1350 	.num_channels = 16,
1351 	.client_id_mask = 0xff,
1352 	.intmask = MC_INT_DECERR_ROUTE_SANITY |
1353 		   MC_INT_DECERR_GENERALIZED_CARVEOUT | MC_INT_DECERR_MTS |
1354 		   MC_INT_SECERR_SEC | MC_INT_DECERR_VPR |
1355 		   MC_INT_SECURITY_VIOLATION | MC_INT_DECERR_EMEM,
1356 	.has_addr_hi_reg = true,
1357 	.ops = &tegra186_mc_ops,
1358 	.icc_ops = &tegra_mc_icc_ops,
1359 	.ch_intmask = 0x00000f00,
1360 	.global_intstatus_channel_shift = 8,
1361 };
1362