tegra30.dtsi 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462
  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. timer@50004600 {
  77. compatible = "arm,cortex-a9-twd-timer";
  78. reg = <0x50040600 0x20>;
  79. interrupts = <1 13 0xf04>;
  80. };
  81. cache-controller@50043000 {
  82. compatible = "arm,pl310-cache";
  83. reg = <0x50043000 0x1000>;
  84. arm,data-latency = <6 6 2>;
  85. arm,tag-latency = <5 5 2>;
  86. cache-unified;
  87. cache-level = <2>;
  88. };
  89. intc: interrupt-controller {
  90. compatible = "arm,cortex-a9-gic";
  91. reg = <0x50041000 0x1000
  92. 0x50040100 0x0100>;
  93. interrupt-controller;
  94. #interrupt-cells = <3>;
  95. };
  96. timer@60005000 {
  97. compatible = "nvidia,tegra30-timer", "nvidia,tegra20-timer";
  98. reg = <0x60005000 0x400>;
  99. interrupts = <0 0 0x04
  100. 0 1 0x04
  101. 0 41 0x04
  102. 0 42 0x04
  103. 0 121 0x04
  104. 0 122 0x04>;
  105. };
  106. tegra_car: clock {
  107. compatible = "nvidia,tegra30-car";
  108. reg = <0x60006000 0x1000>;
  109. #clock-cells = <1>;
  110. };
  111. apbdma: dma {
  112. compatible = "nvidia,tegra30-apbdma", "nvidia,tegra20-apbdma";
  113. reg = <0x6000a000 0x1400>;
  114. interrupts = <0 104 0x04
  115. 0 105 0x04
  116. 0 106 0x04
  117. 0 107 0x04
  118. 0 108 0x04
  119. 0 109 0x04
  120. 0 110 0x04
  121. 0 111 0x04
  122. 0 112 0x04
  123. 0 113 0x04
  124. 0 114 0x04
  125. 0 115 0x04
  126. 0 116 0x04
  127. 0 117 0x04
  128. 0 118 0x04
  129. 0 119 0x04
  130. 0 128 0x04
  131. 0 129 0x04
  132. 0 130 0x04
  133. 0 131 0x04
  134. 0 132 0x04
  135. 0 133 0x04
  136. 0 134 0x04
  137. 0 135 0x04
  138. 0 136 0x04
  139. 0 137 0x04
  140. 0 138 0x04
  141. 0 139 0x04
  142. 0 140 0x04
  143. 0 141 0x04
  144. 0 142 0x04
  145. 0 143 0x04>;
  146. };
  147. ahb: ahb {
  148. compatible = "nvidia,tegra30-ahb";
  149. reg = <0x6000c004 0x14c>; /* AHB Arbitration + Gizmo Controller */
  150. };
  151. gpio: gpio {
  152. compatible = "nvidia,tegra30-gpio", "nvidia,tegra20-gpio";
  153. reg = <0x6000d000 0x1000>;
  154. interrupts = <0 32 0x04
  155. 0 33 0x04
  156. 0 34 0x04
  157. 0 35 0x04
  158. 0 55 0x04
  159. 0 87 0x04
  160. 0 89 0x04
  161. 0 125 0x04>;
  162. #gpio-cells = <2>;
  163. gpio-controller;
  164. #interrupt-cells = <2>;
  165. interrupt-controller;
  166. };
  167. pinmux: pinmux {
  168. compatible = "nvidia,tegra30-pinmux";
  169. reg = <0x70000868 0xd4 /* Pad control registers */
  170. 0x70003000 0x3e4>; /* Mux registers */
  171. };
  172. serial@70006000 {
  173. compatible = "nvidia,tegra30-uart", "nvidia,tegra20-uart";
  174. reg = <0x70006000 0x40>;
  175. reg-shift = <2>;
  176. interrupts = <0 36 0x04>;
  177. status = "disabled";
  178. };
  179. serial@70006040 {
  180. compatible = "nvidia,tegra30-uart", "nvidia,tegra20-uart";
  181. reg = <0x70006040 0x40>;
  182. reg-shift = <2>;
  183. interrupts = <0 37 0x04>;
  184. status = "disabled";
  185. };
  186. serial@70006200 {
  187. compatible = "nvidia,tegra30-uart", "nvidia,tegra20-uart";
  188. reg = <0x70006200 0x100>;
  189. reg-shift = <2>;
  190. interrupts = <0 46 0x04>;
  191. status = "disabled";
  192. };
  193. serial@70006300 {
  194. compatible = "nvidia,tegra30-uart", "nvidia,tegra20-uart";
  195. reg = <0x70006300 0x100>;
  196. reg-shift = <2>;
  197. interrupts = <0 90 0x04>;
  198. status = "disabled";
  199. };
  200. serial@70006400 {
  201. compatible = "nvidia,tegra30-uart", "nvidia,tegra20-uart";
  202. reg = <0x70006400 0x100>;
  203. reg-shift = <2>;
  204. interrupts = <0 91 0x04>;
  205. status = "disabled";
  206. };
  207. pwm: pwm {
  208. compatible = "nvidia,tegra30-pwm", "nvidia,tegra20-pwm";
  209. reg = <0x7000a000 0x100>;
  210. #pwm-cells = <2>;
  211. };
  212. rtc {
  213. compatible = "nvidia,tegra30-rtc", "nvidia,tegra20-rtc";
  214. reg = <0x7000e000 0x100>;
  215. interrupts = <0 2 0x04>;
  216. };
  217. i2c@7000c000 {
  218. compatible = "nvidia,tegra30-i2c", "nvidia,tegra20-i2c";
  219. reg = <0x7000c000 0x100>;
  220. interrupts = <0 38 0x04>;
  221. #address-cells = <1>;
  222. #size-cells = <0>;
  223. status = "disabled";
  224. };
  225. i2c@7000c400 {
  226. compatible = "nvidia,tegra30-i2c", "nvidia,tegra20-i2c";
  227. reg = <0x7000c400 0x100>;
  228. interrupts = <0 84 0x04>;
  229. #address-cells = <1>;
  230. #size-cells = <0>;
  231. status = "disabled";
  232. };
  233. i2c@7000c500 {
  234. compatible = "nvidia,tegra30-i2c", "nvidia,tegra20-i2c";
  235. reg = <0x7000c500 0x100>;
  236. interrupts = <0 92 0x04>;
  237. #address-cells = <1>;
  238. #size-cells = <0>;
  239. status = "disabled";
  240. };
  241. i2c@7000c700 {
  242. compatible = "nvidia,tegra30-i2c", "nvidia,tegra20-i2c";
  243. reg = <0x7000c700 0x100>;
  244. interrupts = <0 120 0x04>;
  245. #address-cells = <1>;
  246. #size-cells = <0>;
  247. status = "disabled";
  248. };
  249. i2c@7000d000 {
  250. compatible = "nvidia,tegra30-i2c", "nvidia,tegra20-i2c";
  251. reg = <0x7000d000 0x100>;
  252. interrupts = <0 53 0x04>;
  253. #address-cells = <1>;
  254. #size-cells = <0>;
  255. status = "disabled";
  256. };
  257. spi@7000d400 {
  258. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  259. reg = <0x7000d400 0x200>;
  260. interrupts = <0 59 0x04>;
  261. nvidia,dma-request-selector = <&apbdma 15>;
  262. #address-cells = <1>;
  263. #size-cells = <0>;
  264. status = "disabled";
  265. };
  266. spi@7000d600 {
  267. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  268. reg = <0x7000d600 0x200>;
  269. interrupts = <0 82 0x04>;
  270. nvidia,dma-request-selector = <&apbdma 16>;
  271. #address-cells = <1>;
  272. #size-cells = <0>;
  273. status = "disabled";
  274. };
  275. spi@7000d800 {
  276. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  277. reg = <0x7000d480 0x200>;
  278. interrupts = <0 83 0x04>;
  279. nvidia,dma-request-selector = <&apbdma 17>;
  280. #address-cells = <1>;
  281. #size-cells = <0>;
  282. status = "disabled";
  283. };
  284. spi@7000da00 {
  285. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  286. reg = <0x7000da00 0x200>;
  287. interrupts = <0 93 0x04>;
  288. nvidia,dma-request-selector = <&apbdma 18>;
  289. #address-cells = <1>;
  290. #size-cells = <0>;
  291. status = "disabled";
  292. };
  293. spi@7000dc00 {
  294. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  295. reg = <0x7000dc00 0x200>;
  296. interrupts = <0 94 0x04>;
  297. nvidia,dma-request-selector = <&apbdma 27>;
  298. #address-cells = <1>;
  299. #size-cells = <0>;
  300. status = "disabled";
  301. };
  302. spi@7000de00 {
  303. compatible = "nvidia,tegra30-slink", "nvidia,tegra20-slink";
  304. reg = <0x7000de00 0x200>;
  305. interrupts = <0 79 0x04>;
  306. nvidia,dma-request-selector = <&apbdma 28>;
  307. #address-cells = <1>;
  308. #size-cells = <0>;
  309. status = "disabled";
  310. };
  311. pmc {
  312. compatible = "nvidia,tegra20-pmc", "nvidia,tegra30-pmc";
  313. reg = <0x7000e400 0x400>;
  314. };
  315. memory-controller {
  316. compatible = "nvidia,tegra30-mc";
  317. reg = <0x7000f000 0x010
  318. 0x7000f03c 0x1b4
  319. 0x7000f200 0x028
  320. 0x7000f284 0x17c>;
  321. interrupts = <0 77 0x04>;
  322. };
  323. smmu {
  324. compatible = "nvidia,tegra30-smmu";
  325. reg = <0x7000f010 0x02c
  326. 0x7000f1f0 0x010
  327. 0x7000f228 0x05c>;
  328. nvidia,#asids = <4>; /* # of ASIDs */
  329. dma-window = <0 0x40000000>; /* IOVA start & length */
  330. nvidia,ahb = <&ahb>;
  331. };
  332. ahub {
  333. compatible = "nvidia,tegra30-ahub";
  334. reg = <0x70080000 0x200
  335. 0x70080200 0x100>;
  336. interrupts = <0 103 0x04>;
  337. nvidia,dma-request-selector = <&apbdma 1>;
  338. ranges;
  339. #address-cells = <1>;
  340. #size-cells = <1>;
  341. tegra_i2s0: i2s@70080300 {
  342. compatible = "nvidia,tegra30-i2s";
  343. reg = <0x70080300 0x100>;
  344. nvidia,ahub-cif-ids = <4 4>;
  345. status = "disabled";
  346. };
  347. tegra_i2s1: i2s@70080400 {
  348. compatible = "nvidia,tegra30-i2s";
  349. reg = <0x70080400 0x100>;
  350. nvidia,ahub-cif-ids = <5 5>;
  351. status = "disabled";
  352. };
  353. tegra_i2s2: i2s@70080500 {
  354. compatible = "nvidia,tegra30-i2s";
  355. reg = <0x70080500 0x100>;
  356. nvidia,ahub-cif-ids = <6 6>;
  357. status = "disabled";
  358. };
  359. tegra_i2s3: i2s@70080600 {
  360. compatible = "nvidia,tegra30-i2s";
  361. reg = <0x70080600 0x100>;
  362. nvidia,ahub-cif-ids = <7 7>;
  363. status = "disabled";
  364. };
  365. tegra_i2s4: i2s@70080700 {
  366. compatible = "nvidia,tegra30-i2s";
  367. reg = <0x70080700 0x100>;
  368. nvidia,ahub-cif-ids = <8 8>;
  369. status = "disabled";
  370. };
  371. };
  372. sdhci@78000000 {
  373. compatible = "nvidia,tegra30-sdhci", "nvidia,tegra20-sdhci";
  374. reg = <0x78000000 0x200>;
  375. interrupts = <0 14 0x04>;
  376. status = "disabled";
  377. };
  378. sdhci@78000200 {
  379. compatible = "nvidia,tegra30-sdhci", "nvidia,tegra20-sdhci";
  380. reg = <0x78000200 0x200>;
  381. interrupts = <0 15 0x04>;
  382. status = "disabled";
  383. };
  384. sdhci@78000400 {
  385. compatible = "nvidia,tegra30-sdhci", "nvidia,tegra20-sdhci";
  386. reg = <0x78000400 0x200>;
  387. interrupts = <0 19 0x04>;
  388. status = "disabled";
  389. };
  390. sdhci@78000600 {
  391. compatible = "nvidia,tegra30-sdhci", "nvidia,tegra20-sdhci";
  392. reg = <0x78000600 0x200>;
  393. interrupts = <0 31 0x04>;
  394. status = "disabled";
  395. };
  396. pmu {
  397. compatible = "arm,cortex-a9-pmu";
  398. interrupts = <0 144 0x04
  399. 0 145 0x04
  400. 0 146 0x04
  401. 0 147 0x04>;
  402. };
  403. };