tegra30.dtsi 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433
  1. /include/ "skeleton.dtsi"
  2. / {
  3. compatible = "nvidia,tegra30";
  4. interrupt-parent = <&intc>;
  5. host1x {
  6. compatible = "nvidia,tegra30-host1x", "simple-bus";
  7. reg = <0x50000000 0x00024000>;
  8. interrupts = <0 65 0x04 /* mpcore syncpt */
  9. 0 67 0x04>; /* mpcore general */
  10. #address-cells = <1>;
  11. #size-cells = <1>;
  12. ranges = <0x54000000 0x54000000 0x04000000>;
  13. mpe {
  14. compatible = "nvidia,tegra30-mpe";
  15. reg = <0x54040000 0x00040000>;
  16. interrupts = <0 68 0x04>;
  17. };
  18. vi {
  19. compatible = "nvidia,tegra30-vi";
  20. reg = <0x54080000 0x00040000>;
  21. interrupts = <0 69 0x04>;
  22. };
  23. epp {
  24. compatible = "nvidia,tegra30-epp";
  25. reg = <0x540c0000 0x00040000>;
  26. interrupts = <0 70 0x04>;
  27. };
  28. isp {
  29. compatible = "nvidia,tegra30-isp";
  30. reg = <0x54100000 0x00040000>;
  31. interrupts = <0 71 0x04>;
  32. };
  33. gr2d {
  34. compatible = "nvidia,tegra30-gr2d";
  35. reg = <0x54140000 0x00040000>;
  36. interrupts = <0 72 0x04>;
  37. };
  38. gr3d {
  39. compatible = "nvidia,tegra30-gr3d";
  40. reg = <0x54180000 0x00040000>;
  41. };
  42. dc@54200000 {
  43. compatible = "nvidia,tegra30-dc";
  44. reg = <0x54200000 0x00040000>;
  45. interrupts = <0 73 0x04>;
  46. rgb {
  47. status = "disabled";
  48. };
  49. };
  50. dc@54240000 {
  51. compatible = "nvidia,tegra30-dc";
  52. reg = <0x54240000 0x00040000>;
  53. interrupts = <0 74 0x04>;
  54. rgb {
  55. status = "disabled";
  56. };
  57. };
  58. hdmi {
  59. compatible = "nvidia,tegra30-hdmi";
  60. reg = <0x54280000 0x00040000>;
  61. interrupts = <0 75 0x04>;
  62. status = "disabled";
  63. };
  64. tvo {
  65. compatible = "nvidia,tegra30-tvo";
  66. reg = <0x542c0000 0x00040000>;
  67. interrupts = <0 76 0x04>;
  68. status = "disabled";
  69. };
  70. dsi {
  71. compatible = "nvidia,tegra30-dsi";
  72. reg = <0x54300000 0x00040000>;
  73. status = "disabled";
  74. };
  75. };
  76. cache-controller@50043000 {
  77. compatible = "arm,pl310-cache";
  78. reg = <0x50043000 0x1000>;
  79. arm,data-latency = <6 6 2>;
  80. arm,tag-latency = <5 5 2>;
  81. cache-unified;
  82. cache-level = <2>;
  83. };
  84. intc: interrupt-controller {
  85. compatible = "arm,cortex-a9-gic";
  86. reg = <0x50041000 0x1000
  87. 0x50040100 0x0100>;
  88. interrupt-controller;
  89. #interrupt-cells = <3>;
  90. };
  91. apbdma: dma {
  92. compatible = "nvidia,tegra30-apbdma", "nvidia,tegra20-apbdma";
  93. reg = <0x6000a000 0x1400>;
  94. interrupts = <0 104 0x04
  95. 0 105 0x04
  96. 0 106 0x04
  97. 0 107 0x04
  98. 0 108 0x04
  99. 0 109 0x04
  100. 0 110 0x04
  101. 0 111 0x04
  102. 0 112 0x04
  103. 0 113 0x04
  104. 0 114 0x04
  105. 0 115 0x04
  106. 0 116 0x04
  107. 0 117 0x04
  108. 0 118 0x04
  109. 0 119 0x04
  110. 0 128 0x04
  111. 0 129 0x04
  112. 0 130 0x04
  113. 0 131 0x04
  114. 0 132 0x04
  115. 0 133 0x04
  116. 0 134 0x04
  117. 0 135 0x04
  118. 0 136 0x04
  119. 0 137 0x04
  120. 0 138 0x04
  121. 0 139 0x04
  122. 0 140 0x04
  123. 0 141 0x04
  124. 0 142 0x04
  125. 0 143 0x04>;
  126. };
  127. ahb: ahb {
  128. compatible = "nvidia,tegra30-ahb";
  129. reg = <0x6000c004 0x14c>; /* AHB Arbitration + Gizmo Controller */
  130. };
  131. gpio: gpio {
  132. compatible = "nvidia,tegra30-gpio", "nvidia,tegra20-gpio";
  133. reg = <0x6000d000 0x1000>;
  134. interrupts = <0 32 0x04
  135. 0 33 0x04
  136. 0 34 0x04
  137. 0 35 0x04
  138. 0 55 0x04
  139. 0 87 0x04
  140. 0 89 0x04
  141. 0 125 0x04>;
  142. #gpio-cells = <2>;
  143. gpio-controller;
  144. #interrupt-cells = <2>;
  145. interrupt-controller;
  146. };
  147. pinmux: pinmux {
  148. compatible = "nvidia,tegra30-pinmux";
  149. reg = <0x70000868 0xd4 /* Pad control registers */
  150. 0x70003000 0x3e4>; /* Mux registers */
  151. };
  152. serial@70006000 {
  153. compatible = "nvidia,tegra30-uart", "nvidia,tegra20-uart";
  154. reg = <0x70006000 0x40>;
  155. reg-shift = <2>;
  156. interrupts = <0 36 0x04>;
  157. status = "disabled";
  158. };
  159. serial@70006040 {
  160. compatible = "nvidia,tegra30-uart", "nvidia,tegra20-uart";
  161. reg = <0x70006040 0x40>;
  162. reg-shift = <2>;
  163. interrupts = <0 37 0x04>;
  164. status = "disabled";
  165. };
  166. serial@70006200 {
  167. compatible = "nvidia,tegra30-uart", "nvidia,tegra20-uart";
  168. reg = <0x70006200 0x100>;
  169. reg-shift = <2>;
  170. interrupts = <0 46 0x04>;
  171. status = "disabled";
  172. };
  173. serial@70006300 {
  174. compatible = "nvidia,tegra30-uart", "nvidia,tegra20-uart";
  175. reg = <0x70006300 0x100>;
  176. reg-shift = <2>;
  177. interrupts = <0 90 0x04>;
  178. status = "disabled";
  179. };
  180. serial@70006400 {
  181. compatible = "nvidia,tegra30-uart", "nvidia,tegra20-uart";
  182. reg = <0x70006400 0x100>;
  183. reg-shift = <2>;
  184. interrupts = <0 91 0x04>;
  185. status = "disabled";
  186. };
  187. pwm: pwm {
  188. compatible = "nvidia,tegra30-pwm", "nvidia,tegra20-pwm";
  189. reg = <0x7000a000 0x100>;
  190. #pwm-cells = <2>;
  191. };
  192. i2c@7000c000 {
  193. compatible = "nvidia,tegra30-i2c", "nvidia,tegra20-i2c";
  194. reg = <0x7000c000 0x100>;
  195. interrupts = <0 38 0x04>;
  196. #address-cells = <1>;
  197. #size-cells = <0>;
  198. status = "disabled";
  199. };
  200. i2c@7000c400 {
  201. compatible = "nvidia,tegra30-i2c", "nvidia,tegra20-i2c";
  202. reg = <0x7000c400 0x100>;
  203. interrupts = <0 84 0x04>;
  204. #address-cells = <1>;
  205. #size-cells = <0>;
  206. status = "disabled";
  207. };
  208. i2c@7000c500 {
  209. compatible = "nvidia,tegra30-i2c", "nvidia,tegra20-i2c";
  210. reg = <0x7000c500 0x100>;
  211. interrupts = <0 92 0x04>;
  212. #address-cells = <1>;
  213. #size-cells = <0>;
  214. status = "disabled";
  215. };
  216. i2c@7000c700 {
  217. compatible = "nvidia,tegra30-i2c", "nvidia,tegra20-i2c";
  218. reg = <0x7000c700 0x100>;
  219. interrupts = <0 120 0x04>;
  220. #address-cells = <1>;
  221. #size-cells = <0>;
  222. status = "disabled";
  223. };
  224. i2c@7000d000 {
  225. compatible = "nvidia,tegra30-i2c", "nvidia,tegra20-i2c";
  226. reg = <0x7000d000 0x100>;
  227. interrupts = <0 53 0x04>;
  228. #address-cells = <1>;
  229. #size-cells = <0>;
  230. status = "disabled";
  231. };
  232. spi@7000d400 {
  233. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  234. reg = <0x7000d400 0x200>;
  235. interrupts = <0 59 0x04>;
  236. nvidia,dma-request-selector = <&apbdma 15>;
  237. #address-cells = <1>;
  238. #size-cells = <0>;
  239. status = "disabled";
  240. };
  241. spi@7000d600 {
  242. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  243. reg = <0x7000d600 0x200>;
  244. interrupts = <0 82 0x04>;
  245. nvidia,dma-request-selector = <&apbdma 16>;
  246. #address-cells = <1>;
  247. #size-cells = <0>;
  248. status = "disabled";
  249. };
  250. spi@7000d800 {
  251. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  252. reg = <0x7000d480 0x200>;
  253. interrupts = <0 83 0x04>;
  254. nvidia,dma-request-selector = <&apbdma 17>;
  255. #address-cells = <1>;
  256. #size-cells = <0>;
  257. status = "disabled";
  258. };
  259. spi@7000da00 {
  260. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  261. reg = <0x7000da00 0x200>;
  262. interrupts = <0 93 0x04>;
  263. nvidia,dma-request-selector = <&apbdma 18>;
  264. #address-cells = <1>;
  265. #size-cells = <0>;
  266. status = "disabled";
  267. };
  268. spi@7000dc00 {
  269. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  270. reg = <0x7000dc00 0x200>;
  271. interrupts = <0 94 0x04>;
  272. nvidia,dma-request-selector = <&apbdma 27>;
  273. #address-cells = <1>;
  274. #size-cells = <0>;
  275. status = "disabled";
  276. };
  277. spi@7000de00 {
  278. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  279. reg = <0x7000de00 0x200>;
  280. interrupts = <0 79 0x04>;
  281. nvidia,dma-request-selector = <&apbdma 28>;
  282. #address-cells = <1>;
  283. #size-cells = <0>;
  284. status = "disabled";
  285. };
  286. pmc {
  287. compatible = "nvidia,tegra20-pmc", "nvidia,tegra30-pmc";
  288. reg = <0x7000e400 0x400>;
  289. };
  290. memory-controller {
  291. compatible = "nvidia,tegra30-mc";
  292. reg = <0x7000f000 0x010
  293. 0x7000f03c 0x1b4
  294. 0x7000f200 0x028
  295. 0x7000f284 0x17c>;
  296. interrupts = <0 77 0x04>;
  297. };
  298. smmu {
  299. compatible = "nvidia,tegra30-smmu";
  300. reg = <0x7000f010 0x02c
  301. 0x7000f1f0 0x010
  302. 0x7000f228 0x05c>;
  303. nvidia,#asids = <4>; /* # of ASIDs */
  304. dma-window = <0 0x40000000>; /* IOVA start & length */
  305. nvidia,ahb = <&ahb>;
  306. };
  307. ahub {
  308. compatible = "nvidia,tegra30-ahub";
  309. reg = <0x70080000 0x200
  310. 0x70080200 0x100>;
  311. interrupts = <0 103 0x04>;
  312. nvidia,dma-request-selector = <&apbdma 1>;
  313. ranges;
  314. #address-cells = <1>;
  315. #size-cells = <1>;
  316. tegra_i2s0: i2s@70080300 {
  317. compatible = "nvidia,tegra30-i2s";
  318. reg = <0x70080300 0x100>;
  319. nvidia,ahub-cif-ids = <4 4>;
  320. status = "disabled";
  321. };
  322. tegra_i2s1: i2s@70080400 {
  323. compatible = "nvidia,tegra30-i2s";
  324. reg = <0x70080400 0x100>;
  325. nvidia,ahub-cif-ids = <5 5>;
  326. status = "disabled";
  327. };
  328. tegra_i2s2: i2s@70080500 {
  329. compatible = "nvidia,tegra30-i2s";
  330. reg = <0x70080500 0x100>;
  331. nvidia,ahub-cif-ids = <6 6>;
  332. status = "disabled";
  333. };
  334. tegra_i2s3: i2s@70080600 {
  335. compatible = "nvidia,tegra30-i2s";
  336. reg = <0x70080600 0x100>;
  337. nvidia,ahub-cif-ids = <7 7>;
  338. status = "disabled";
  339. };
  340. tegra_i2s4: i2s@70080700 {
  341. compatible = "nvidia,tegra30-i2s";
  342. reg = <0x70080700 0x100>;
  343. nvidia,ahub-cif-ids = <8 8>;
  344. status = "disabled";
  345. };
  346. };
  347. sdhci@78000000 {
  348. compatible = "nvidia,tegra30-sdhci", "nvidia,tegra20-sdhci";
  349. reg = <0x78000000 0x200>;
  350. interrupts = <0 14 0x04>;
  351. status = "disabled";
  352. };
  353. sdhci@78000200 {
  354. compatible = "nvidia,tegra30-sdhci", "nvidia,tegra20-sdhci";
  355. reg = <0x78000200 0x200>;
  356. interrupts = <0 15 0x04>;
  357. status = "disabled";
  358. };
  359. sdhci@78000400 {
  360. compatible = "nvidia,tegra30-sdhci", "nvidia,tegra20-sdhci";
  361. reg = <0x78000400 0x200>;
  362. interrupts = <0 19 0x04>;
  363. status = "disabled";
  364. };
  365. sdhci@78000600 {
  366. compatible = "nvidia,tegra30-sdhci", "nvidia,tegra20-sdhci";
  367. reg = <0x78000600 0x200>;
  368. interrupts = <0 31 0x04>;
  369. status = "disabled";
  370. };
  371. pmu {
  372. compatible = "arm,cortex-a9-pmu";
  373. interrupts = <0 144 0x04
  374. 0 145 0x04
  375. 0 146 0x04
  376. 0 147 0x04>;
  377. };
  378. };