tegra210.c 22 KB

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