omap5.dtsi 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500
  1. /*
  2. * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2 as
  6. * published by the Free Software Foundation.
  7. * Based on "omap4.dtsi"
  8. */
  9. /*
  10. * Carveout for multimedia usecases
  11. * It should be the last 48MB of the first 512MB memory part
  12. * In theory, it should not even exist. That zone should be reserved
  13. * dynamically during the .reserve callback.
  14. */
  15. /memreserve/ 0x9d000000 0x03000000;
  16. /include/ "skeleton.dtsi"
  17. / {
  18. compatible = "ti,omap5";
  19. interrupt-parent = <&gic>;
  20. aliases {
  21. serial0 = &uart1;
  22. serial1 = &uart2;
  23. serial2 = &uart3;
  24. serial3 = &uart4;
  25. serial4 = &uart5;
  26. serial5 = &uart6;
  27. };
  28. cpus {
  29. cpu@0 {
  30. compatible = "arm,cortex-a15";
  31. timer {
  32. compatible = "arm,armv7-timer";
  33. /* 14th PPI IRQ, active low level-sensitive */
  34. interrupts = <1 14 0x308>;
  35. clock-frequency = <6144000>;
  36. };
  37. };
  38. cpu@1 {
  39. compatible = "arm,cortex-a15";
  40. timer {
  41. compatible = "arm,armv7-timer";
  42. /* 14th PPI IRQ, active low level-sensitive */
  43. interrupts = <1 14 0x308>;
  44. clock-frequency = <6144000>;
  45. };
  46. };
  47. };
  48. /*
  49. * The soc node represents the soc top level view. It is uses for IPs
  50. * that are not memory mapped in the MPU view or for the MPU itself.
  51. */
  52. soc {
  53. compatible = "ti,omap-infra";
  54. mpu {
  55. compatible = "ti,omap5-mpu";
  56. ti,hwmods = "mpu";
  57. };
  58. };
  59. /*
  60. * XXX: Use a flat representation of the OMAP3 interconnect.
  61. * The real OMAP interconnect network is quite complex.
  62. * Since that will not bring real advantage to represent that in DT for
  63. * the moment, just use a fake OCP bus entry to represent the whole bus
  64. * hierarchy.
  65. */
  66. ocp {
  67. compatible = "ti,omap4-l3-noc", "simple-bus";
  68. #address-cells = <1>;
  69. #size-cells = <1>;
  70. ranges;
  71. ti,hwmods = "l3_main_1", "l3_main_2", "l3_main_3";
  72. counter32k: counter@4ae04000 {
  73. compatible = "ti,omap-counter32k";
  74. reg = <0x4ae04000 0x40>;
  75. ti,hwmods = "counter_32k";
  76. };
  77. omap5_pmx_core: pinmux@4a002840 {
  78. compatible = "ti,omap4-padconf", "pinctrl-single";
  79. reg = <0x4a002840 0x01b6>;
  80. #address-cells = <1>;
  81. #size-cells = <0>;
  82. pinctrl-single,register-width = <16>;
  83. pinctrl-single,function-mask = <0x7fff>;
  84. };
  85. omap5_pmx_wkup: pinmux@4ae0c840 {
  86. compatible = "ti,omap4-padconf", "pinctrl-single";
  87. reg = <0x4ae0c840 0x0038>;
  88. #address-cells = <1>;
  89. #size-cells = <0>;
  90. pinctrl-single,register-width = <16>;
  91. pinctrl-single,function-mask = <0x7fff>;
  92. };
  93. gic: interrupt-controller@48211000 {
  94. compatible = "arm,cortex-a15-gic";
  95. interrupt-controller;
  96. #interrupt-cells = <3>;
  97. reg = <0x48211000 0x1000>,
  98. <0x48212000 0x1000>;
  99. };
  100. gpio1: gpio@4ae10000 {
  101. compatible = "ti,omap4-gpio";
  102. reg = <0x4ae10000 0x200>;
  103. interrupts = <0 29 0x4>;
  104. ti,hwmods = "gpio1";
  105. gpio-controller;
  106. #gpio-cells = <2>;
  107. interrupt-controller;
  108. #interrupt-cells = <1>;
  109. };
  110. gpio2: gpio@48055000 {
  111. compatible = "ti,omap4-gpio";
  112. reg = <0x48055000 0x200>;
  113. interrupts = <0 30 0x4>;
  114. ti,hwmods = "gpio2";
  115. gpio-controller;
  116. #gpio-cells = <2>;
  117. interrupt-controller;
  118. #interrupt-cells = <1>;
  119. };
  120. gpio3: gpio@48057000 {
  121. compatible = "ti,omap4-gpio";
  122. reg = <0x48057000 0x200>;
  123. interrupts = <0 31 0x4>;
  124. ti,hwmods = "gpio3";
  125. gpio-controller;
  126. #gpio-cells = <2>;
  127. interrupt-controller;
  128. #interrupt-cells = <1>;
  129. };
  130. gpio4: gpio@48059000 {
  131. compatible = "ti,omap4-gpio";
  132. reg = <0x48059000 0x200>;
  133. interrupts = <0 32 0x4>;
  134. ti,hwmods = "gpio4";
  135. gpio-controller;
  136. #gpio-cells = <2>;
  137. interrupt-controller;
  138. #interrupt-cells = <1>;
  139. };
  140. gpio5: gpio@4805b000 {
  141. compatible = "ti,omap4-gpio";
  142. reg = <0x4805b000 0x200>;
  143. interrupts = <0 33 0x4>;
  144. ti,hwmods = "gpio5";
  145. gpio-controller;
  146. #gpio-cells = <2>;
  147. interrupt-controller;
  148. #interrupt-cells = <1>;
  149. };
  150. gpio6: gpio@4805d000 {
  151. compatible = "ti,omap4-gpio";
  152. reg = <0x4805d000 0x200>;
  153. interrupts = <0 34 0x4>;
  154. ti,hwmods = "gpio6";
  155. gpio-controller;
  156. #gpio-cells = <2>;
  157. interrupt-controller;
  158. #interrupt-cells = <1>;
  159. };
  160. gpio7: gpio@48051000 {
  161. compatible = "ti,omap4-gpio";
  162. reg = <0x48051000 0x200>;
  163. interrupts = <0 35 0x4>;
  164. ti,hwmods = "gpio7";
  165. gpio-controller;
  166. #gpio-cells = <2>;
  167. interrupt-controller;
  168. #interrupt-cells = <1>;
  169. };
  170. gpio8: gpio@48053000 {
  171. compatible = "ti,omap4-gpio";
  172. reg = <0x48053000 0x200>;
  173. interrupts = <0 121 0x4>;
  174. ti,hwmods = "gpio8";
  175. gpio-controller;
  176. #gpio-cells = <2>;
  177. interrupt-controller;
  178. #interrupt-cells = <1>;
  179. };
  180. i2c1: i2c@48070000 {
  181. compatible = "ti,omap4-i2c";
  182. reg = <0x48070000 0x100>;
  183. interrupts = <0 56 0x4>;
  184. #address-cells = <1>;
  185. #size-cells = <0>;
  186. ti,hwmods = "i2c1";
  187. };
  188. i2c2: i2c@48072000 {
  189. compatible = "ti,omap4-i2c";
  190. reg = <0x48072000 0x100>;
  191. interrupts = <0 57 0x4>;
  192. #address-cells = <1>;
  193. #size-cells = <0>;
  194. ti,hwmods = "i2c2";
  195. };
  196. i2c3: i2c@48060000 {
  197. compatible = "ti,omap4-i2c";
  198. reg = <0x48060000 0x100>;
  199. interrupts = <0 61 0x4>;
  200. #address-cells = <1>;
  201. #size-cells = <0>;
  202. ti,hwmods = "i2c3";
  203. };
  204. i2c4: i2c@4807a000 {
  205. compatible = "ti,omap4-i2c";
  206. reg = <0x4807a000 0x100>;
  207. interrupts = <0 62 0x4>;
  208. #address-cells = <1>;
  209. #size-cells = <0>;
  210. ti,hwmods = "i2c4";
  211. };
  212. i2c5: i2c@4807c000 {
  213. compatible = "ti,omap4-i2c";
  214. reg = <0x4807c000 0x100>;
  215. interrupts = <0 60 0x4>;
  216. #address-cells = <1>;
  217. #size-cells = <0>;
  218. ti,hwmods = "i2c5";
  219. };
  220. uart1: serial@4806a000 {
  221. compatible = "ti,omap4-uart";
  222. reg = <0x4806a000 0x100>;
  223. interrupts = <0 72 0x4>;
  224. ti,hwmods = "uart1";
  225. clock-frequency = <48000000>;
  226. };
  227. uart2: serial@4806c000 {
  228. compatible = "ti,omap4-uart";
  229. reg = <0x4806c000 0x100>;
  230. interrupts = <0 73 0x4>;
  231. ti,hwmods = "uart2";
  232. clock-frequency = <48000000>;
  233. };
  234. uart3: serial@48020000 {
  235. compatible = "ti,omap4-uart";
  236. reg = <0x48020000 0x100>;
  237. interrupts = <0 74 0x4>;
  238. ti,hwmods = "uart3";
  239. clock-frequency = <48000000>;
  240. };
  241. uart4: serial@4806e000 {
  242. compatible = "ti,omap4-uart";
  243. reg = <0x4806e000 0x100>;
  244. interrupts = <0 70 0x4>;
  245. ti,hwmods = "uart4";
  246. clock-frequency = <48000000>;
  247. };
  248. uart5: serial@48066000 {
  249. compatible = "ti,omap4-uart";
  250. reg = <0x48066000 0x100>;
  251. interrupts = <0 105 0x4>;
  252. ti,hwmods = "uart5";
  253. clock-frequency = <48000000>;
  254. };
  255. uart6: serial@48068000 {
  256. compatible = "ti,omap4-uart";
  257. reg = <0x48068000 0x100>;
  258. interrupts = <0 106 0x4>;
  259. ti,hwmods = "uart6";
  260. clock-frequency = <48000000>;
  261. };
  262. mmc1: mmc@4809c000 {
  263. compatible = "ti,omap4-hsmmc";
  264. reg = <0x4809c000 0x400>;
  265. interrupts = <0 83 0x4>;
  266. ti,hwmods = "mmc1";
  267. ti,dual-volt;
  268. ti,needs-special-reset;
  269. };
  270. mmc2: mmc@480b4000 {
  271. compatible = "ti,omap4-hsmmc";
  272. reg = <0x480b4000 0x400>;
  273. interrupts = <0 86 0x4>;
  274. ti,hwmods = "mmc2";
  275. ti,needs-special-reset;
  276. };
  277. mmc3: mmc@480ad000 {
  278. compatible = "ti,omap4-hsmmc";
  279. reg = <0x480ad000 0x400>;
  280. interrupts = <0 94 0x4>;
  281. ti,hwmods = "mmc3";
  282. ti,needs-special-reset;
  283. };
  284. mmc4: mmc@480d1000 {
  285. compatible = "ti,omap4-hsmmc";
  286. reg = <0x480d1000 0x400>;
  287. interrupts = <0 96 0x4>;
  288. ti,hwmods = "mmc4";
  289. ti,needs-special-reset;
  290. };
  291. mmc5: mmc@480d5000 {
  292. compatible = "ti,omap4-hsmmc";
  293. reg = <0x480d5000 0x400>;
  294. interrupts = <0 59 0x4>;
  295. ti,hwmods = "mmc5";
  296. ti,needs-special-reset;
  297. };
  298. keypad: keypad@4ae1c000 {
  299. compatible = "ti,omap4-keypad";
  300. ti,hwmods = "kbd";
  301. };
  302. mcpdm: mcpdm@40132000 {
  303. compatible = "ti,omap4-mcpdm";
  304. reg = <0x40132000 0x7f>, /* MPU private access */
  305. <0x49032000 0x7f>; /* L3 Interconnect */
  306. reg-names = "mpu", "dma";
  307. interrupts = <0 112 0x4>;
  308. ti,hwmods = "mcpdm";
  309. };
  310. dmic: dmic@4012e000 {
  311. compatible = "ti,omap4-dmic";
  312. reg = <0x4012e000 0x7f>, /* MPU private access */
  313. <0x4902e000 0x7f>; /* L3 Interconnect */
  314. reg-names = "mpu", "dma";
  315. interrupts = <0 114 0x4>;
  316. ti,hwmods = "dmic";
  317. };
  318. mcbsp1: mcbsp@40122000 {
  319. compatible = "ti,omap4-mcbsp";
  320. reg = <0x40122000 0xff>, /* MPU private access */
  321. <0x49022000 0xff>; /* L3 Interconnect */
  322. reg-names = "mpu", "dma";
  323. interrupts = <0 17 0x4>;
  324. interrupt-names = "common";
  325. ti,buffer-size = <128>;
  326. ti,hwmods = "mcbsp1";
  327. };
  328. mcbsp2: mcbsp@40124000 {
  329. compatible = "ti,omap4-mcbsp";
  330. reg = <0x40124000 0xff>, /* MPU private access */
  331. <0x49024000 0xff>; /* L3 Interconnect */
  332. reg-names = "mpu", "dma";
  333. interrupts = <0 22 0x4>;
  334. interrupt-names = "common";
  335. ti,buffer-size = <128>;
  336. ti,hwmods = "mcbsp2";
  337. };
  338. mcbsp3: mcbsp@40126000 {
  339. compatible = "ti,omap4-mcbsp";
  340. reg = <0x40126000 0xff>, /* MPU private access */
  341. <0x49026000 0xff>; /* L3 Interconnect */
  342. reg-names = "mpu", "dma";
  343. interrupts = <0 23 0x4>;
  344. interrupt-names = "common";
  345. ti,buffer-size = <128>;
  346. ti,hwmods = "mcbsp3";
  347. };
  348. timer1: timer@4ae18000 {
  349. compatible = "ti,omap2-timer";
  350. reg = <0x4ae18000 0x80>;
  351. interrupts = <0 37 0x4>;
  352. ti,hwmods = "timer1";
  353. ti,timer-alwon;
  354. };
  355. timer2: timer@48032000 {
  356. compatible = "ti,omap2-timer";
  357. reg = <0x48032000 0x80>;
  358. interrupts = <0 38 0x4>;
  359. ti,hwmods = "timer2";
  360. };
  361. timer3: timer@48034000 {
  362. compatible = "ti,omap2-timer";
  363. reg = <0x48034000 0x80>;
  364. interrupts = <0 39 0x4>;
  365. ti,hwmods = "timer3";
  366. };
  367. timer4: timer@48036000 {
  368. compatible = "ti,omap2-timer";
  369. reg = <0x48036000 0x80>;
  370. interrupts = <0 40 0x4>;
  371. ti,hwmods = "timer4";
  372. };
  373. timer5: timer@40138000 {
  374. compatible = "ti,omap2-timer";
  375. reg = <0x40138000 0x80>,
  376. <0x49038000 0x80>;
  377. interrupts = <0 41 0x4>;
  378. ti,hwmods = "timer5";
  379. ti,timer-dsp;
  380. };
  381. timer6: timer@4013a000 {
  382. compatible = "ti,omap2-timer";
  383. reg = <0x4013a000 0x80>,
  384. <0x4903a000 0x80>;
  385. interrupts = <0 42 0x4>;
  386. ti,hwmods = "timer6";
  387. ti,timer-dsp;
  388. ti,timer-pwm;
  389. };
  390. timer7: timer@4013c000 {
  391. compatible = "ti,omap2-timer";
  392. reg = <0x4013c000 0x80>,
  393. <0x4903c000 0x80>;
  394. interrupts = <0 43 0x4>;
  395. ti,hwmods = "timer7";
  396. ti,timer-dsp;
  397. };
  398. timer8: timer@4013e000 {
  399. compatible = "ti,omap2-timer";
  400. reg = <0x4013e000 0x80>,
  401. <0x4903e000 0x80>;
  402. interrupts = <0 44 0x4>;
  403. ti,hwmods = "timer8";
  404. ti,timer-dsp;
  405. ti,timer-pwm;
  406. };
  407. timer9: timer@4803e000 {
  408. compatible = "ti,omap2-timer";
  409. reg = <0x4803e000 0x80>;
  410. interrupts = <0 45 0x4>;
  411. ti,hwmods = "timer9";
  412. };
  413. timer10: timer@48086000 {
  414. compatible = "ti,omap2-timer";
  415. reg = <0x48086000 0x80>;
  416. interrupts = <0 46 0x4>;
  417. ti,hwmods = "timer10";
  418. };
  419. timer11: timer@48088000 {
  420. compatible = "ti,omap2-timer";
  421. reg = <0x48088000 0x80>;
  422. interrupts = <0 47 0x4>;
  423. ti,hwmods = "timer11";
  424. ti,timer-pwm;
  425. };
  426. emif1: emif@0x4c000000 {
  427. compatible = "ti,emif-4d5";
  428. ti,hwmods = "emif1";
  429. phy-type = <2>; /* DDR PHY type: Intelli PHY */
  430. reg = <0x4c000000 0x400>;
  431. interrupts = <0 110 0x4>;
  432. hw-caps-read-idle-ctrl;
  433. hw-caps-ll-interface;
  434. hw-caps-temp-alert;
  435. };
  436. emif2: emif@0x4d000000 {
  437. compatible = "ti,emif-4d5";
  438. ti,hwmods = "emif2";
  439. phy-type = <2>; /* DDR PHY type: Intelli PHY */
  440. reg = <0x4d000000 0x400>;
  441. interrupts = <0 111 0x4>;
  442. hw-caps-read-idle-ctrl;
  443. hw-caps-ll-interface;
  444. hw-caps-temp-alert;
  445. };
  446. };
  447. };