xref: /openbmc/linux/drivers/memory/tegra/tegra210.c (revision b1a792601f264df7172a728f1a83a05b6b399dfb)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Copyright (C) 2015 NVIDIA CORPORATION.  All rights reserved.
4  */
5 
6 #include <dt-bindings/memory/tegra210-mc.h>
7 
8 #include "mc.h"
9 
10 static const struct tegra_mc_client tegra210_mc_clients[] = {
11 	{
12 		.id = 0x00,
13 		.name = "ptcr",
14 		.swgroup = TEGRA_SWGROUP_PTC,
15 	}, {
16 		.id = 0x01,
17 		.name = "display0a",
18 		.swgroup = TEGRA_SWGROUP_DC,
19 		.smmu = {
20 			.reg = 0x228,
21 			.bit = 1,
22 		},
23 		.la = {
24 			.reg = 0x2e8,
25 			.shift = 0,
26 			.mask = 0xff,
27 			.def = 0x1e,
28 		},
29 	}, {
30 		.id = 0x02,
31 		.name = "display0ab",
32 		.swgroup = TEGRA_SWGROUP_DCB,
33 		.smmu = {
34 			.reg = 0x228,
35 			.bit = 2,
36 		},
37 		.la = {
38 			.reg = 0x2f4,
39 			.shift = 0,
40 			.mask = 0xff,
41 			.def = 0x1e,
42 		},
43 	}, {
44 		.id = 0x03,
45 		.name = "display0b",
46 		.swgroup = TEGRA_SWGROUP_DC,
47 		.smmu = {
48 			.reg = 0x228,
49 			.bit = 3,
50 		},
51 		.la = {
52 			.reg = 0x2e8,
53 			.shift = 16,
54 			.mask = 0xff,
55 			.def = 0x1e,
56 		},
57 	}, {
58 		.id = 0x04,
59 		.name = "display0bb",
60 		.swgroup = TEGRA_SWGROUP_DCB,
61 		.smmu = {
62 			.reg = 0x228,
63 			.bit = 4,
64 		},
65 		.la = {
66 			.reg = 0x2f4,
67 			.shift = 16,
68 			.mask = 0xff,
69 			.def = 0x1e,
70 		},
71 	}, {
72 		.id = 0x05,
73 		.name = "display0c",
74 		.swgroup = TEGRA_SWGROUP_DC,
75 		.smmu = {
76 			.reg = 0x228,
77 			.bit = 5,
78 		},
79 		.la = {
80 			.reg = 0x2ec,
81 			.shift = 0,
82 			.mask = 0xff,
83 			.def = 0x1e,
84 		},
85 	}, {
86 		.id = 0x06,
87 		.name = "display0cb",
88 		.swgroup = TEGRA_SWGROUP_DCB,
89 		.smmu = {
90 			.reg = 0x228,
91 			.bit = 6,
92 		},
93 		.la = {
94 			.reg = 0x2f8,
95 			.shift = 0,
96 			.mask = 0xff,
97 			.def = 0x1e,
98 		},
99 	}, {
100 		.id = 0x0e,
101 		.name = "afir",
102 		.swgroup = TEGRA_SWGROUP_AFI,
103 		.smmu = {
104 			.reg = 0x228,
105 			.bit = 14,
106 		},
107 		.la = {
108 			.reg = 0x2e0,
109 			.shift = 0,
110 			.mask = 0xff,
111 			.def = 0x2e,
112 		},
113 	}, {
114 		.id = 0x0f,
115 		.name = "avpcarm7r",
116 		.swgroup = TEGRA_SWGROUP_AVPC,
117 		.smmu = {
118 			.reg = 0x228,
119 			.bit = 15,
120 		},
121 		.la = {
122 			.reg = 0x2e4,
123 			.shift = 0,
124 			.mask = 0xff,
125 			.def = 0x04,
126 		},
127 	}, {
128 		.id = 0x10,
129 		.name = "displayhc",
130 		.swgroup = TEGRA_SWGROUP_DC,
131 		.smmu = {
132 			.reg = 0x228,
133 			.bit = 16,
134 		},
135 		.la = {
136 			.reg = 0x2f0,
137 			.shift = 0,
138 			.mask = 0xff,
139 			.def = 0x1e,
140 		},
141 	}, {
142 		.id = 0x11,
143 		.name = "displayhcb",
144 		.swgroup = TEGRA_SWGROUP_DCB,
145 		.smmu = {
146 			.reg = 0x228,
147 			.bit = 17,
148 		},
149 		.la = {
150 			.reg = 0x2fc,
151 			.shift = 0,
152 			.mask = 0xff,
153 			.def = 0x1e,
154 		},
155 	}, {
156 		.id = 0x15,
157 		.name = "hdar",
158 		.swgroup = TEGRA_SWGROUP_HDA,
159 		.smmu = {
160 			.reg = 0x228,
161 			.bit = 21,
162 		},
163 		.la = {
164 			.reg = 0x318,
165 			.shift = 0,
166 			.mask = 0xff,
167 			.def = 0x24,
168 		},
169 	}, {
170 		.id = 0x16,
171 		.name = "host1xdmar",
172 		.swgroup = TEGRA_SWGROUP_HC,
173 		.smmu = {
174 			.reg = 0x228,
175 			.bit = 22,
176 		},
177 		.la = {
178 			.reg = 0x310,
179 			.shift = 0,
180 			.mask = 0xff,
181 			.def = 0x1e,
182 		},
183 	}, {
184 		.id = 0x17,
185 		.name = "host1xr",
186 		.swgroup = TEGRA_SWGROUP_HC,
187 		.smmu = {
188 			.reg = 0x228,
189 			.bit = 23,
190 		},
191 		.la = {
192 			.reg = 0x310,
193 			.shift = 16,
194 			.mask = 0xff,
195 			.def = 0x50,
196 		},
197 	}, {
198 		.id = 0x1c,
199 		.name = "nvencsrd",
200 		.swgroup = TEGRA_SWGROUP_NVENC,
201 		.smmu = {
202 			.reg = 0x228,
203 			.bit = 28,
204 		},
205 		.la = {
206 			.reg = 0x328,
207 			.shift = 0,
208 			.mask = 0xff,
209 			.def = 0x23,
210 		},
211 	}, {
212 		.id = 0x1d,
213 		.name = "ppcsahbdmar",
214 		.swgroup = TEGRA_SWGROUP_PPCS,
215 		.smmu = {
216 			.reg = 0x228,
217 			.bit = 29,
218 		},
219 		.la = {
220 			.reg = 0x344,
221 			.shift = 0,
222 			.mask = 0xff,
223 			.def = 0x49,
224 		},
225 	}, {
226 		.id = 0x1e,
227 		.name = "ppcsahbslvr",
228 		.swgroup = TEGRA_SWGROUP_PPCS,
229 		.smmu = {
230 			.reg = 0x228,
231 			.bit = 30,
232 		},
233 		.la = {
234 			.reg = 0x344,
235 			.shift = 16,
236 			.mask = 0xff,
237 			.def = 0x1a,
238 		},
239 	}, {
240 		.id = 0x1f,
241 		.name = "satar",
242 		.swgroup = TEGRA_SWGROUP_SATA,
243 		.smmu = {
244 			.reg = 0x228,
245 			.bit = 31,
246 		},
247 		.la = {
248 			.reg = 0x350,
249 			.shift = 0,
250 			.mask = 0xff,
251 			.def = 0x65,
252 		},
253 	}, {
254 		.id = 0x27,
255 		.name = "mpcorer",
256 		.swgroup = TEGRA_SWGROUP_MPCORE,
257 		.la = {
258 			.reg = 0x320,
259 			.shift = 0,
260 			.mask = 0xff,
261 			.def = 0x04,
262 		},
263 	}, {
264 		.id = 0x2b,
265 		.name = "nvencswr",
266 		.swgroup = TEGRA_SWGROUP_NVENC,
267 		.smmu = {
268 			.reg = 0x22c,
269 			.bit = 11,
270 		},
271 		.la = {
272 			.reg = 0x328,
273 			.shift = 16,
274 			.mask = 0xff,
275 			.def = 0x80,
276 		},
277 	}, {
278 		.id = 0x31,
279 		.name = "afiw",
280 		.swgroup = TEGRA_SWGROUP_AFI,
281 		.smmu = {
282 			.reg = 0x22c,
283 			.bit = 17,
284 		},
285 		.la = {
286 			.reg = 0x2e0,
287 			.shift = 16,
288 			.mask = 0xff,
289 			.def = 0x80,
290 		},
291 	}, {
292 		.id = 0x32,
293 		.name = "avpcarm7w",
294 		.swgroup = TEGRA_SWGROUP_AVPC,
295 		.smmu = {
296 			.reg = 0x22c,
297 			.bit = 18,
298 		},
299 		.la = {
300 			.reg = 0x2e4,
301 			.shift = 16,
302 			.mask = 0xff,
303 			.def = 0x80,
304 		},
305 	}, {
306 		.id = 0x35,
307 		.name = "hdaw",
308 		.swgroup = TEGRA_SWGROUP_HDA,
309 		.smmu = {
310 			.reg = 0x22c,
311 			.bit = 21,
312 		},
313 		.la = {
314 			.reg = 0x318,
315 			.shift = 16,
316 			.mask = 0xff,
317 			.def = 0x80,
318 		},
319 	}, {
320 		.id = 0x36,
321 		.name = "host1xw",
322 		.swgroup = TEGRA_SWGROUP_HC,
323 		.smmu = {
324 			.reg = 0x22c,
325 			.bit = 22,
326 		},
327 		.la = {
328 			.reg = 0x314,
329 			.shift = 0,
330 			.mask = 0xff,
331 			.def = 0x80,
332 		},
333 	}, {
334 		.id = 0x39,
335 		.name = "mpcorew",
336 		.swgroup = TEGRA_SWGROUP_MPCORE,
337 		.la = {
338 			.reg = 0x320,
339 			.shift = 16,
340 			.mask = 0xff,
341 			.def = 0x80,
342 		},
343 	}, {
344 		.id = 0x3b,
345 		.name = "ppcsahbdmaw",
346 		.swgroup = TEGRA_SWGROUP_PPCS,
347 		.smmu = {
348 			.reg = 0x22c,
349 			.bit = 27,
350 		},
351 		.la = {
352 			.reg = 0x348,
353 			.shift = 0,
354 			.mask = 0xff,
355 			.def = 0x80,
356 		},
357 	}, {
358 		.id = 0x3c,
359 		.name = "ppcsahbslvw",
360 		.swgroup = TEGRA_SWGROUP_PPCS,
361 		.smmu = {
362 			.reg = 0x22c,
363 			.bit = 28,
364 		},
365 		.la = {
366 			.reg = 0x348,
367 			.shift = 16,
368 			.mask = 0xff,
369 			.def = 0x80,
370 		},
371 	}, {
372 		.id = 0x3d,
373 		.name = "sataw",
374 		.swgroup = TEGRA_SWGROUP_SATA,
375 		.smmu = {
376 			.reg = 0x22c,
377 			.bit = 29,
378 		},
379 		.la = {
380 			.reg = 0x350,
381 			.shift = 16,
382 			.mask = 0xff,
383 			.def = 0x80,
384 		},
385 	}, {
386 		.id = 0x44,
387 		.name = "ispra",
388 		.swgroup = TEGRA_SWGROUP_ISP2,
389 		.smmu = {
390 			.reg = 0x230,
391 			.bit = 4,
392 		},
393 		.la = {
394 			.reg = 0x370,
395 			.shift = 0,
396 			.mask = 0xff,
397 			.def = 0x18,
398 		},
399 	}, {
400 		.id = 0x46,
401 		.name = "ispwa",
402 		.swgroup = TEGRA_SWGROUP_ISP2,
403 		.smmu = {
404 			.reg = 0x230,
405 			.bit = 6,
406 		},
407 		.la = {
408 			.reg = 0x374,
409 			.shift = 0,
410 			.mask = 0xff,
411 			.def = 0x80,
412 		},
413 	}, {
414 		.id = 0x47,
415 		.name = "ispwb",
416 		.swgroup = TEGRA_SWGROUP_ISP2,
417 		.smmu = {
418 			.reg = 0x230,
419 			.bit = 7,
420 		},
421 		.la = {
422 			.reg = 0x374,
423 			.shift = 16,
424 			.mask = 0xff,
425 			.def = 0x80,
426 		},
427 	}, {
428 		.id = 0x4a,
429 		.name = "xusb_hostr",
430 		.swgroup = TEGRA_SWGROUP_XUSB_HOST,
431 		.smmu = {
432 			.reg = 0x230,
433 			.bit = 10,
434 		},
435 		.la = {
436 			.reg = 0x37c,
437 			.shift = 0,
438 			.mask = 0xff,
439 			.def = 0x7a,
440 		},
441 	}, {
442 		.id = 0x4b,
443 		.name = "xusb_hostw",
444 		.swgroup = TEGRA_SWGROUP_XUSB_HOST,
445 		.smmu = {
446 			.reg = 0x230,
447 			.bit = 11,
448 		},
449 		.la = {
450 			.reg = 0x37c,
451 			.shift = 16,
452 			.mask = 0xff,
453 			.def = 0x80,
454 		},
455 	}, {
456 		.id = 0x4c,
457 		.name = "xusb_devr",
458 		.swgroup = TEGRA_SWGROUP_XUSB_DEV,
459 		.smmu = {
460 			.reg = 0x230,
461 			.bit = 12,
462 		},
463 		.la = {
464 			.reg = 0x380,
465 			.shift = 0,
466 			.mask = 0xff,
467 			.def = 0x39,
468 		},
469 	}, {
470 		.id = 0x4d,
471 		.name = "xusb_devw",
472 		.swgroup = TEGRA_SWGROUP_XUSB_DEV,
473 		.smmu = {
474 			.reg = 0x230,
475 			.bit = 13,
476 		},
477 		.la = {
478 			.reg = 0x380,
479 			.shift = 16,
480 			.mask = 0xff,
481 			.def = 0x80,
482 		},
483 	}, {
484 		.id = 0x4e,
485 		.name = "isprab",
486 		.swgroup = TEGRA_SWGROUP_ISP2B,
487 		.smmu = {
488 			.reg = 0x230,
489 			.bit = 14,
490 		},
491 		.la = {
492 			.reg = 0x384,
493 			.shift = 0,
494 			.mask = 0xff,
495 			.def = 0x18,
496 		},
497 	}, {
498 		.id = 0x50,
499 		.name = "ispwab",
500 		.swgroup = TEGRA_SWGROUP_ISP2B,
501 		.smmu = {
502 			.reg = 0x230,
503 			.bit = 16,
504 		},
505 		.la = {
506 			.reg = 0x388,
507 			.shift = 0,
508 			.mask = 0xff,
509 			.def = 0x80,
510 		},
511 	}, {
512 		.id = 0x51,
513 		.name = "ispwbb",
514 		.swgroup = TEGRA_SWGROUP_ISP2B,
515 		.smmu = {
516 			.reg = 0x230,
517 			.bit = 17,
518 		},
519 		.la = {
520 			.reg = 0x388,
521 			.shift = 16,
522 			.mask = 0xff,
523 			.def = 0x80,
524 		},
525 	}, {
526 		.id = 0x54,
527 		.name = "tsecsrd",
528 		.swgroup = TEGRA_SWGROUP_TSEC,
529 		.smmu = {
530 			.reg = 0x230,
531 			.bit = 20,
532 		},
533 		.la = {
534 			.reg = 0x390,
535 			.shift = 0,
536 			.mask = 0xff,
537 			.def = 0x9b,
538 		},
539 	}, {
540 		.id = 0x55,
541 		.name = "tsecswr",
542 		.swgroup = TEGRA_SWGROUP_TSEC,
543 		.smmu = {
544 			.reg = 0x230,
545 			.bit = 21,
546 		},
547 		.la = {
548 			.reg = 0x390,
549 			.shift = 16,
550 			.mask = 0xff,
551 			.def = 0x80,
552 		},
553 	}, {
554 		.id = 0x56,
555 		.name = "a9avpscr",
556 		.swgroup = TEGRA_SWGROUP_A9AVP,
557 		.smmu = {
558 			.reg = 0x230,
559 			.bit = 22,
560 		},
561 		.la = {
562 			.reg = 0x3a4,
563 			.shift = 0,
564 			.mask = 0xff,
565 			.def = 0x04,
566 		},
567 	}, {
568 		.id = 0x57,
569 		.name = "a9avpscw",
570 		.swgroup = TEGRA_SWGROUP_A9AVP,
571 		.smmu = {
572 			.reg = 0x230,
573 			.bit = 23,
574 		},
575 		.la = {
576 			.reg = 0x3a4,
577 			.shift = 16,
578 			.mask = 0xff,
579 			.def = 0x80,
580 		},
581 	}, {
582 		.id = 0x58,
583 		.name = "gpusrd",
584 		.swgroup = TEGRA_SWGROUP_GPU,
585 		.smmu = {
586 			/* read-only */
587 			.reg = 0x230,
588 			.bit = 24,
589 		},
590 		.la = {
591 			.reg = 0x3c8,
592 			.shift = 0,
593 			.mask = 0xff,
594 			.def = 0x1a,
595 		},
596 	}, {
597 		.id = 0x59,
598 		.name = "gpuswr",
599 		.swgroup = TEGRA_SWGROUP_GPU,
600 		.smmu = {
601 			/* read-only */
602 			.reg = 0x230,
603 			.bit = 25,
604 		},
605 		.la = {
606 			.reg = 0x3c8,
607 			.shift = 16,
608 			.mask = 0xff,
609 			.def = 0x80,
610 		},
611 	}, {
612 		.id = 0x5a,
613 		.name = "displayt",
614 		.swgroup = TEGRA_SWGROUP_DC,
615 		.smmu = {
616 			.reg = 0x230,
617 			.bit = 26,
618 		},
619 		.la = {
620 			.reg = 0x2f0,
621 			.shift = 16,
622 			.mask = 0xff,
623 			.def = 0x1e,
624 		},
625 	}, {
626 		.id = 0x60,
627 		.name = "sdmmcra",
628 		.swgroup = TEGRA_SWGROUP_SDMMC1A,
629 		.smmu = {
630 			.reg = 0x234,
631 			.bit = 0,
632 		},
633 		.la = {
634 			.reg = 0x3b8,
635 			.shift = 0,
636 			.mask = 0xff,
637 			.def = 0x49,
638 		},
639 	}, {
640 		.id = 0x61,
641 		.name = "sdmmcraa",
642 		.swgroup = TEGRA_SWGROUP_SDMMC2A,
643 		.smmu = {
644 			.reg = 0x234,
645 			.bit = 1,
646 		},
647 		.la = {
648 			.reg = 0x3bc,
649 			.shift = 0,
650 			.mask = 0xff,
651 			.def = 0x5a,
652 		},
653 	}, {
654 		.id = 0x62,
655 		.name = "sdmmcr",
656 		.swgroup = TEGRA_SWGROUP_SDMMC3A,
657 		.smmu = {
658 			.reg = 0x234,
659 			.bit = 2,
660 		},
661 		.la = {
662 			.reg = 0x3c0,
663 			.shift = 0,
664 			.mask = 0xff,
665 			.def = 0x49,
666 		},
667 	}, {
668 		.id = 0x63,
669 		.swgroup = TEGRA_SWGROUP_SDMMC4A,
670 		.name = "sdmmcrab",
671 		.smmu = {
672 			.reg = 0x234,
673 			.bit = 3,
674 		},
675 		.la = {
676 			.reg = 0x3c4,
677 			.shift = 0,
678 			.mask = 0xff,
679 			.def = 0x5a,
680 		},
681 	}, {
682 		.id = 0x64,
683 		.name = "sdmmcwa",
684 		.swgroup = TEGRA_SWGROUP_SDMMC1A,
685 		.smmu = {
686 			.reg = 0x234,
687 			.bit = 4,
688 		},
689 		.la = {
690 			.reg = 0x3b8,
691 			.shift = 16,
692 			.mask = 0xff,
693 			.def = 0x80,
694 		},
695 	}, {
696 		.id = 0x65,
697 		.name = "sdmmcwaa",
698 		.swgroup = TEGRA_SWGROUP_SDMMC2A,
699 		.smmu = {
700 			.reg = 0x234,
701 			.bit = 5,
702 		},
703 		.la = {
704 			.reg = 0x3bc,
705 			.shift = 16,
706 			.mask = 0xff,
707 			.def = 0x80,
708 		},
709 	}, {
710 		.id = 0x66,
711 		.name = "sdmmcw",
712 		.swgroup = TEGRA_SWGROUP_SDMMC3A,
713 		.smmu = {
714 			.reg = 0x234,
715 			.bit = 6,
716 		},
717 		.la = {
718 			.reg = 0x3c0,
719 			.shift = 16,
720 			.mask = 0xff,
721 			.def = 0x80,
722 		},
723 	}, {
724 		.id = 0x67,
725 		.name = "sdmmcwab",
726 		.swgroup = TEGRA_SWGROUP_SDMMC4A,
727 		.smmu = {
728 			.reg = 0x234,
729 			.bit = 7,
730 		},
731 		.la = {
732 			.reg = 0x3c4,
733 			.shift = 16,
734 			.mask = 0xff,
735 			.def = 0x80,
736 		},
737 	}, {
738 		.id = 0x6c,
739 		.name = "vicsrd",
740 		.swgroup = TEGRA_SWGROUP_VIC,
741 		.smmu = {
742 			.reg = 0x234,
743 			.bit = 12,
744 		},
745 		.la = {
746 			.reg = 0x394,
747 			.shift = 0,
748 			.mask = 0xff,
749 			.def = 0x1a,
750 		},
751 	}, {
752 		.id = 0x6d,
753 		.name = "vicswr",
754 		.swgroup = TEGRA_SWGROUP_VIC,
755 		.smmu = {
756 			.reg = 0x234,
757 			.bit = 13,
758 		},
759 		.la = {
760 			.reg = 0x394,
761 			.shift = 16,
762 			.mask = 0xff,
763 			.def = 0x80,
764 		},
765 	}, {
766 		.id = 0x72,
767 		.name = "viw",
768 		.swgroup = TEGRA_SWGROUP_VI,
769 		.smmu = {
770 			.reg = 0x234,
771 			.bit = 18,
772 		},
773 		.la = {
774 			.reg = 0x398,
775 			.shift = 0,
776 			.mask = 0xff,
777 			.def = 0x80,
778 		},
779 	}, {
780 		.id = 0x73,
781 		.name = "displayd",
782 		.swgroup = TEGRA_SWGROUP_DC,
783 		.smmu = {
784 			.reg = 0x234,
785 			.bit = 19,
786 		},
787 		.la = {
788 			.reg = 0x3c8,
789 			.shift = 0,
790 			.mask = 0xff,
791 			.def = 0x50,
792 		},
793 	}, {
794 		.id = 0x78,
795 		.name = "nvdecsrd",
796 		.swgroup = TEGRA_SWGROUP_NVDEC,
797 		.smmu = {
798 			.reg = 0x234,
799 			.bit = 24,
800 		},
801 		.la = {
802 			.reg = 0x3d8,
803 			.shift = 0,
804 			.mask = 0xff,
805 			.def = 0x23,
806 		},
807 	}, {
808 		.id = 0x79,
809 		.name = "nvdecswr",
810 		.swgroup = TEGRA_SWGROUP_NVDEC,
811 		.smmu = {
812 			.reg = 0x234,
813 			.bit = 25,
814 		},
815 		.la = {
816 			.reg = 0x3d8,
817 			.shift = 16,
818 			.mask = 0xff,
819 			.def = 0x80,
820 		},
821 	}, {
822 		.id = 0x7a,
823 		.name = "aper",
824 		.swgroup = TEGRA_SWGROUP_APE,
825 		.smmu = {
826 			.reg = 0x234,
827 			.bit = 26,
828 		},
829 		.la = {
830 			.reg = 0x3dc,
831 			.shift = 0,
832 			.mask = 0xff,
833 			.def = 0xff,
834 		},
835 	}, {
836 		.id = 0x7b,
837 		.name = "apew",
838 		.swgroup = TEGRA_SWGROUP_APE,
839 		.smmu = {
840 			.reg = 0x234,
841 			.bit = 27,
842 		},
843 		.la = {
844 			.reg = 0x3dc,
845 			.shift = 16,
846 			.mask = 0xff,
847 			.def = 0x80,
848 		},
849 	}, {
850 		.id = 0x7e,
851 		.name = "nvjpgsrd",
852 		.swgroup = TEGRA_SWGROUP_NVJPG,
853 		.smmu = {
854 			.reg = 0x234,
855 			.bit = 30,
856 		},
857 		.la = {
858 			.reg = 0x3e4,
859 			.shift = 0,
860 			.mask = 0xff,
861 			.def = 0x23,
862 		},
863 	}, {
864 		.id = 0x7f,
865 		.name = "nvjpgswr",
866 		.swgroup = TEGRA_SWGROUP_NVJPG,
867 		.smmu = {
868 			.reg = 0x234,
869 			.bit = 31,
870 		},
871 		.la = {
872 			.reg = 0x3e4,
873 			.shift = 16,
874 			.mask = 0xff,
875 			.def = 0x80,
876 		},
877 	}, {
878 		.id = 0x80,
879 		.name = "sesrd",
880 		.swgroup = TEGRA_SWGROUP_SE,
881 		.smmu = {
882 			.reg = 0xb98,
883 			.bit = 0,
884 		},
885 		.la = {
886 			.reg = 0x3e0,
887 			.shift = 0,
888 			.mask = 0xff,
889 			.def = 0x2e,
890 		},
891 	}, {
892 		.id = 0x81,
893 		.name = "seswr",
894 		.swgroup = TEGRA_SWGROUP_SE,
895 		.smmu = {
896 			.reg = 0xb98,
897 			.bit = 1,
898 		},
899 		.la = {
900 			.reg = 0x3e0,
901 			.shift = 16,
902 			.mask = 0xff,
903 			.def = 0x80,
904 		},
905 	}, {
906 		.id = 0x82,
907 		.name = "axiapr",
908 		.swgroup = TEGRA_SWGROUP_AXIAP,
909 		.smmu = {
910 			.reg = 0xb98,
911 			.bit = 2,
912 		},
913 		.la = {
914 			.reg = 0x3a0,
915 			.shift = 0,
916 			.mask = 0xff,
917 			.def = 0xff,
918 		},
919 	}, {
920 		.id = 0x83,
921 		.name = "axiapw",
922 		.swgroup = TEGRA_SWGROUP_AXIAP,
923 		.smmu = {
924 			.reg = 0xb98,
925 			.bit = 3,
926 		},
927 		.la = {
928 			.reg = 0x3a0,
929 			.shift = 16,
930 			.mask = 0xff,
931 			.def = 0x80,
932 		},
933 	}, {
934 		.id = 0x84,
935 		.name = "etrr",
936 		.swgroup = TEGRA_SWGROUP_ETR,
937 		.smmu = {
938 			.reg = 0xb98,
939 			.bit = 4,
940 		},
941 		.la = {
942 			.reg = 0x3ec,
943 			.shift = 0,
944 			.mask = 0xff,
945 			.def = 0xff,
946 		},
947 	}, {
948 		.id = 0x85,
949 		.name = "etrw",
950 		.swgroup = TEGRA_SWGROUP_ETR,
951 		.smmu = {
952 			.reg = 0xb98,
953 			.bit = 5,
954 		},
955 		.la = {
956 			.reg = 0x3ec,
957 			.shift = 16,
958 			.mask = 0xff,
959 			.def = 0x80,
960 		},
961 	}, {
962 		.id = 0x86,
963 		.name = "tsecsrdb",
964 		.swgroup = TEGRA_SWGROUP_TSECB,
965 		.smmu = {
966 			.reg = 0xb98,
967 			.bit = 6,
968 		},
969 		.la = {
970 			.reg = 0x3f0,
971 			.shift = 0,
972 			.mask = 0xff,
973 			.def = 0x9b,
974 		},
975 	}, {
976 		.id = 0x87,
977 		.name = "tsecswrb",
978 		.swgroup = TEGRA_SWGROUP_TSECB,
979 		.smmu = {
980 			.reg = 0xb98,
981 			.bit = 7,
982 		},
983 		.la = {
984 			.reg = 0x3f0,
985 			.shift = 16,
986 			.mask = 0xff,
987 			.def = 0x80,
988 		},
989 	}, {
990 		.id = 0x88,
991 		.name = "gpusrd2",
992 		.swgroup = TEGRA_SWGROUP_GPU,
993 		.smmu = {
994 			/* read-only */
995 			.reg = 0xb98,
996 			.bit = 8,
997 		},
998 		.la = {
999 			.reg = 0x3e8,
1000 			.shift = 0,
1001 			.mask = 0xff,
1002 			.def = 0x1a,
1003 		},
1004 	}, {
1005 		.id = 0x89,
1006 		.name = "gpuswr2",
1007 		.swgroup = TEGRA_SWGROUP_GPU,
1008 		.smmu = {
1009 			/* read-only */
1010 			.reg = 0xb98,
1011 			.bit = 9,
1012 		},
1013 		.la = {
1014 			.reg = 0x3e8,
1015 			.shift = 16,
1016 			.mask = 0xff,
1017 			.def = 0x80,
1018 		},
1019 	},
1020 };
1021 
1022 static const struct tegra_smmu_swgroup tegra210_swgroups[] = {
1023 	{ .name = "afi",       .swgroup = TEGRA_SWGROUP_AFI,       .reg = 0x238 },
1024 	{ .name = "avpc",      .swgroup = TEGRA_SWGROUP_AVPC,      .reg = 0x23c },
1025 	{ .name = "dc",        .swgroup = TEGRA_SWGROUP_DC,        .reg = 0x240 },
1026 	{ .name = "dcb",       .swgroup = TEGRA_SWGROUP_DCB,       .reg = 0x244 },
1027 	{ .name = "hc",        .swgroup = TEGRA_SWGROUP_HC,        .reg = 0x250 },
1028 	{ .name = "hda",       .swgroup = TEGRA_SWGROUP_HDA,       .reg = 0x254 },
1029 	{ .name = "isp2",      .swgroup = TEGRA_SWGROUP_ISP2,      .reg = 0x258 },
1030 	{ .name = "nvenc",     .swgroup = TEGRA_SWGROUP_NVENC,     .reg = 0x264 },
1031 	{ .name = "nv",        .swgroup = TEGRA_SWGROUP_NV,        .reg = 0x268 },
1032 	{ .name = "nv2",       .swgroup = TEGRA_SWGROUP_NV2,       .reg = 0x26c },
1033 	{ .name = "ppcs",      .swgroup = TEGRA_SWGROUP_PPCS,      .reg = 0x270 },
1034 	{ .name = "sata",      .swgroup = TEGRA_SWGROUP_SATA,      .reg = 0x274 },
1035 	{ .name = "vi",        .swgroup = TEGRA_SWGROUP_VI,        .reg = 0x280 },
1036 	{ .name = "vic",       .swgroup = TEGRA_SWGROUP_VIC,       .reg = 0x284 },
1037 	{ .name = "xusb_host", .swgroup = TEGRA_SWGROUP_XUSB_HOST, .reg = 0x288 },
1038 	{ .name = "xusb_dev",  .swgroup = TEGRA_SWGROUP_XUSB_DEV,  .reg = 0x28c },
1039 	{ .name = "a9avp",     .swgroup = TEGRA_SWGROUP_A9AVP,     .reg = 0x290 },
1040 	{ .name = "tsec",      .swgroup = TEGRA_SWGROUP_TSEC,      .reg = 0x294 },
1041 	{ .name = "ppcs1",     .swgroup = TEGRA_SWGROUP_PPCS1,     .reg = 0x298 },
1042 	{ .name = "dc1",       .swgroup = TEGRA_SWGROUP_DC1,       .reg = 0xa88 },
1043 	{ .name = "sdmmc1a",   .swgroup = TEGRA_SWGROUP_SDMMC1A,   .reg = 0xa94 },
1044 	{ .name = "sdmmc2a",   .swgroup = TEGRA_SWGROUP_SDMMC2A,   .reg = 0xa98 },
1045 	{ .name = "sdmmc3a",   .swgroup = TEGRA_SWGROUP_SDMMC3A,   .reg = 0xa9c },
1046 	{ .name = "sdmmc4a",   .swgroup = TEGRA_SWGROUP_SDMMC4A,   .reg = 0xaa0 },
1047 	{ .name = "isp2b",     .swgroup = TEGRA_SWGROUP_ISP2B,     .reg = 0xaa4 },
1048 	{ .name = "gpu",       .swgroup = TEGRA_SWGROUP_GPU,       .reg = 0xaac },
1049 	{ .name = "ppcs2",     .swgroup = TEGRA_SWGROUP_PPCS2,     .reg = 0xab0 },
1050 	{ .name = "nvdec",     .swgroup = TEGRA_SWGROUP_NVDEC,     .reg = 0xab4 },
1051 	{ .name = "ape",       .swgroup = TEGRA_SWGROUP_APE,       .reg = 0xab8 },
1052 	{ .name = "se",        .swgroup = TEGRA_SWGROUP_SE,        .reg = 0xabc },
1053 	{ .name = "nvjpg",     .swgroup = TEGRA_SWGROUP_NVJPG,     .reg = 0xac0 },
1054 	{ .name = "hc1",       .swgroup = TEGRA_SWGROUP_HC1,       .reg = 0xac4 },
1055 	{ .name = "se1",       .swgroup = TEGRA_SWGROUP_SE1,       .reg = 0xac8 },
1056 	{ .name = "axiap",     .swgroup = TEGRA_SWGROUP_AXIAP,     .reg = 0xacc },
1057 	{ .name = "etr",       .swgroup = TEGRA_SWGROUP_ETR,       .reg = 0xad0 },
1058 	{ .name = "tsecb",     .swgroup = TEGRA_SWGROUP_TSECB,     .reg = 0xad4 },
1059 	{ .name = "tsec1",     .swgroup = TEGRA_SWGROUP_TSEC1,     .reg = 0xad8 },
1060 	{ .name = "tsecb1",    .swgroup = TEGRA_SWGROUP_TSECB1,    .reg = 0xadc },
1061 	{ .name = "nvdec1",    .swgroup = TEGRA_SWGROUP_NVDEC1,    .reg = 0xae0 },
1062 };
1063 
1064 static const unsigned int tegra210_group_display[] = {
1065 	TEGRA_SWGROUP_DC,
1066 	TEGRA_SWGROUP_DCB,
1067 };
1068 
1069 static const struct tegra_smmu_group_soc tegra210_groups[] = {
1070 	{
1071 		.name = "display",
1072 		.swgroups = tegra210_group_display,
1073 		.num_swgroups = ARRAY_SIZE(tegra210_group_display),
1074 	},
1075 };
1076 
1077 static const struct tegra_smmu_soc tegra210_smmu_soc = {
1078 	.clients = tegra210_mc_clients,
1079 	.num_clients = ARRAY_SIZE(tegra210_mc_clients),
1080 	.swgroups = tegra210_swgroups,
1081 	.num_swgroups = ARRAY_SIZE(tegra210_swgroups),
1082 	.groups = tegra210_groups,
1083 	.num_groups = ARRAY_SIZE(tegra210_groups),
1084 	.supports_round_robin_arbitration = true,
1085 	.supports_request_limit = true,
1086 	.num_tlb_lines = 48,
1087 	.num_asids = 128,
1088 };
1089 
1090 #define TEGRA210_MC_RESET(_name, _control, _status, _bit)	\
1091 	{							\
1092 		.name = #_name,					\
1093 		.id = TEGRA210_MC_RESET_##_name,		\
1094 		.control = _control,				\
1095 		.status = _status,				\
1096 		.bit = _bit,					\
1097 	}
1098 
1099 static const struct tegra_mc_reset tegra210_mc_resets[] = {
1100 	TEGRA210_MC_RESET(AFI,       0x200, 0x204,  0),
1101 	TEGRA210_MC_RESET(AVPC,      0x200, 0x204,  1),
1102 	TEGRA210_MC_RESET(DC,        0x200, 0x204,  2),
1103 	TEGRA210_MC_RESET(DCB,       0x200, 0x204,  3),
1104 	TEGRA210_MC_RESET(HC,        0x200, 0x204,  6),
1105 	TEGRA210_MC_RESET(HDA,       0x200, 0x204,  7),
1106 	TEGRA210_MC_RESET(ISP2,      0x200, 0x204,  8),
1107 	TEGRA210_MC_RESET(MPCORE,    0x200, 0x204,  9),
1108 	TEGRA210_MC_RESET(NVENC,     0x200, 0x204, 11),
1109 	TEGRA210_MC_RESET(PPCS,      0x200, 0x204, 14),
1110 	TEGRA210_MC_RESET(SATA,      0x200, 0x204, 15),
1111 	TEGRA210_MC_RESET(VI,        0x200, 0x204, 17),
1112 	TEGRA210_MC_RESET(VIC,       0x200, 0x204, 18),
1113 	TEGRA210_MC_RESET(XUSB_HOST, 0x200, 0x204, 19),
1114 	TEGRA210_MC_RESET(XUSB_DEV,  0x200, 0x204, 20),
1115 	TEGRA210_MC_RESET(A9AVP,     0x200, 0x204, 21),
1116 	TEGRA210_MC_RESET(TSEC,      0x200, 0x204, 22),
1117 	TEGRA210_MC_RESET(SDMMC1,    0x200, 0x204, 29),
1118 	TEGRA210_MC_RESET(SDMMC2,    0x200, 0x204, 30),
1119 	TEGRA210_MC_RESET(SDMMC3,    0x200, 0x204, 31),
1120 	TEGRA210_MC_RESET(SDMMC4,    0x970, 0x974,  0),
1121 	TEGRA210_MC_RESET(ISP2B,     0x970, 0x974,  1),
1122 	TEGRA210_MC_RESET(GPU,       0x970, 0x974,  2),
1123 	TEGRA210_MC_RESET(NVDEC,     0x970, 0x974,  5),
1124 	TEGRA210_MC_RESET(APE,       0x970, 0x974,  6),
1125 	TEGRA210_MC_RESET(SE,        0x970, 0x974,  7),
1126 	TEGRA210_MC_RESET(NVJPG,     0x970, 0x974,  8),
1127 	TEGRA210_MC_RESET(AXIAP,     0x970, 0x974, 11),
1128 	TEGRA210_MC_RESET(ETR,       0x970, 0x974, 12),
1129 	TEGRA210_MC_RESET(TSECB,     0x970, 0x974, 13),
1130 };
1131 
1132 const struct tegra_mc_soc tegra210_mc_soc = {
1133 	.clients = tegra210_mc_clients,
1134 	.num_clients = ARRAY_SIZE(tegra210_mc_clients),
1135 	.num_address_bits = 34,
1136 	.atom_size = 64,
1137 	.client_id_mask = 0xff,
1138 	.smmu = &tegra210_smmu_soc,
1139 	.intmask = MC_INT_DECERR_MTS | MC_INT_SECERR_SEC | MC_INT_DECERR_VPR |
1140 		   MC_INT_INVALID_APB_ASID_UPDATE | MC_INT_INVALID_SMMU_PAGE |
1141 		   MC_INT_SECURITY_VIOLATION | MC_INT_DECERR_EMEM,
1142 	.reset_ops = &tegra_mc_reset_ops_common,
1143 	.resets = tegra210_mc_resets,
1144 	.num_resets = ARRAY_SIZE(tegra210_mc_resets),
1145 };
1146