versatile-ab.dts 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. /dts-v1/;
  2. /include/ "skeleton.dtsi"
  3. / {
  4. model = "ARM Versatile AB";
  5. compatible = "arm,versatile-ab";
  6. #address-cells = <1>;
  7. #size-cells = <1>;
  8. interrupt-parent = <&vic>;
  9. aliases {
  10. serial0 = &uart0;
  11. serial1 = &uart1;
  12. serial2 = &uart2;
  13. i2c0 = &i2c0;
  14. };
  15. chosen {
  16. stdout-path = &uart0;
  17. };
  18. memory {
  19. reg = <0x0 0x08000000>;
  20. };
  21. xtal24mhz: xtal24mhz@24M {
  22. #clock-cells = <0>;
  23. compatible = "fixed-clock";
  24. clock-frequency = <24000000>;
  25. };
  26. core-module@10000000 {
  27. compatible = "arm,core-module-versatile", "syscon";
  28. reg = <0x10000000 0x200>;
  29. /* OSC1 on AB, OSC4 on PB */
  30. osc1: cm_aux_osc@24M {
  31. #clock-cells = <0>;
  32. compatible = "arm,versatile-cm-auxosc";
  33. clocks = <&xtal24mhz>;
  34. };
  35. /* The timer clock is the 24 MHz oscillator divided to 1MHz */
  36. timclk: timclk@1M {
  37. #clock-cells = <0>;
  38. compatible = "fixed-factor-clock";
  39. clock-div = <24>;
  40. clock-mult = <1>;
  41. clocks = <&xtal24mhz>;
  42. };
  43. pclk: pclk@24M {
  44. #clock-cells = <0>;
  45. compatible = "fixed-factor-clock";
  46. clock-div = <1>;
  47. clock-mult = <1>;
  48. clocks = <&xtal24mhz>;
  49. };
  50. };
  51. flash@34000000 {
  52. compatible = "arm,versatile-flash";
  53. reg = <0x34000000 0x4000000>;
  54. bank-width = <4>;
  55. };
  56. i2c0: i2c@10002000 {
  57. #address-cells = <1>;
  58. #size-cells = <0>;
  59. compatible = "arm,versatile-i2c";
  60. reg = <0x10002000 0x1000>;
  61. rtc@68 {
  62. compatible = "dallas,ds1338";
  63. reg = <0x68>;
  64. };
  65. };
  66. net@10010000 {
  67. compatible = "smsc,lan91c111";
  68. reg = <0x10010000 0x10000>;
  69. interrupts = <25>;
  70. };
  71. lcd@10008000 {
  72. compatible = "arm,versatile-lcd";
  73. reg = <0x10008000 0x1000>;
  74. };
  75. amba {
  76. compatible = "arm,amba-bus";
  77. #address-cells = <1>;
  78. #size-cells = <1>;
  79. ranges;
  80. vic: intc@10140000 {
  81. compatible = "arm,versatile-vic";
  82. interrupt-controller;
  83. #interrupt-cells = <1>;
  84. reg = <0x10140000 0x1000>;
  85. clear-mask = <0xffffffff>;
  86. valid-mask = <0xffffffff>;
  87. };
  88. sic: intc@10003000 {
  89. compatible = "arm,versatile-sic";
  90. interrupt-controller;
  91. #interrupt-cells = <1>;
  92. reg = <0x10003000 0x1000>;
  93. interrupt-parent = <&vic>;
  94. interrupts = <31>; /* Cascaded to vic */
  95. clear-mask = <0xffffffff>;
  96. valid-mask = <0xffc203f8>;
  97. };
  98. dma@10130000 {
  99. compatible = "arm,pl081", "arm,primecell";
  100. reg = <0x10130000 0x1000>;
  101. interrupts = <17>;
  102. clocks = <&pclk>;
  103. clock-names = "apb_pclk";
  104. };
  105. uart0: uart@101f1000 {
  106. compatible = "arm,pl011", "arm,primecell";
  107. reg = <0x101f1000 0x1000>;
  108. interrupts = <12>;
  109. clocks = <&xtal24mhz>, <&pclk>;
  110. clock-names = "uartclk", "apb_pclk";
  111. };
  112. uart1: uart@101f2000 {
  113. compatible = "arm,pl011", "arm,primecell";
  114. reg = <0x101f2000 0x1000>;
  115. interrupts = <13>;
  116. clocks = <&xtal24mhz>, <&pclk>;
  117. clock-names = "uartclk", "apb_pclk";
  118. };
  119. uart2: uart@101f3000 {
  120. compatible = "arm,pl011", "arm,primecell";
  121. reg = <0x101f3000 0x1000>;
  122. interrupts = <14>;
  123. clocks = <&xtal24mhz>, <&pclk>;
  124. clock-names = "uartclk", "apb_pclk";
  125. };
  126. smc@10100000 {
  127. compatible = "arm,primecell";
  128. reg = <0x10100000 0x1000>;
  129. clocks = <&pclk>;
  130. clock-names = "apb_pclk";
  131. };
  132. mpmc@10110000 {
  133. compatible = "arm,primecell";
  134. reg = <0x10110000 0x1000>;
  135. clocks = <&pclk>;
  136. clock-names = "apb_pclk";
  137. };
  138. display@10120000 {
  139. compatible = "arm,pl110", "arm,primecell";
  140. reg = <0x10120000 0x1000>;
  141. interrupts = <16>;
  142. clocks = <&osc1>, <&pclk>;
  143. clock-names = "clcd", "apb_pclk";
  144. };
  145. sctl@101e0000 {
  146. compatible = "arm,primecell";
  147. reg = <0x101e0000 0x1000>;
  148. clocks = <&pclk>;
  149. clock-names = "apb_pclk";
  150. };
  151. watchdog@101e1000 {
  152. compatible = "arm,primecell";
  153. reg = <0x101e1000 0x1000>;
  154. interrupts = <0>;
  155. clocks = <&pclk>;
  156. clock-names = "apb_pclk";
  157. };
  158. timer@101e2000 {
  159. compatible = "arm,sp804", "arm,primecell";
  160. reg = <0x101e2000 0x1000>;
  161. interrupts = <4>;
  162. clocks = <&timclk>, <&timclk>, <&pclk>;
  163. clock-names = "timer0", "timer1", "apb_pclk";
  164. };
  165. timer@101e3000 {
  166. compatible = "arm,sp804", "arm,primecell";
  167. reg = <0x101e3000 0x1000>;
  168. interrupts = <5>;
  169. clocks = <&timclk>, <&timclk>, <&pclk>;
  170. clock-names = "timer0", "timer1", "apb_pclk";
  171. };
  172. gpio0: gpio@101e4000 {
  173. compatible = "arm,pl061", "arm,primecell";
  174. reg = <0x101e4000 0x1000>;
  175. gpio-controller;
  176. interrupts = <6>;
  177. #gpio-cells = <2>;
  178. interrupt-controller;
  179. #interrupt-cells = <2>;
  180. clocks = <&pclk>;
  181. clock-names = "apb_pclk";
  182. };
  183. gpio1: gpio@101e5000 {
  184. compatible = "arm,pl061", "arm,primecell";
  185. reg = <0x101e5000 0x1000>;
  186. interrupts = <7>;
  187. gpio-controller;
  188. #gpio-cells = <2>;
  189. interrupt-controller;
  190. #interrupt-cells = <2>;
  191. clocks = <&pclk>;
  192. clock-names = "apb_pclk";
  193. };
  194. rtc@101e8000 {
  195. compatible = "arm,pl030", "arm,primecell";
  196. reg = <0x101e8000 0x1000>;
  197. interrupts = <10>;
  198. clocks = <&pclk>;
  199. clock-names = "apb_pclk";
  200. };
  201. sci@101f0000 {
  202. compatible = "arm,primecell";
  203. reg = <0x101f0000 0x1000>;
  204. interrupts = <15>;
  205. clocks = <&pclk>;
  206. clock-names = "apb_pclk";
  207. };
  208. ssp@101f4000 {
  209. compatible = "arm,pl022", "arm,primecell";
  210. reg = <0x101f4000 0x1000>;
  211. interrupts = <11>;
  212. clocks = <&xtal24mhz>, <&pclk>;
  213. clock-names = "SSPCLK", "apb_pclk";
  214. };
  215. fpga {
  216. compatible = "arm,versatile-fpga", "simple-bus";
  217. #address-cells = <1>;
  218. #size-cells = <1>;
  219. ranges = <0 0x10000000 0x10000>;
  220. aaci@4000 {
  221. compatible = "arm,primecell";
  222. reg = <0x4000 0x1000>;
  223. interrupts = <24>;
  224. clocks = <&pclk>;
  225. clock-names = "apb_pclk";
  226. };
  227. mmc@5000 {
  228. compatible = "arm,pl180", "arm,primecell";
  229. reg = < 0x5000 0x1000>;
  230. interrupts-extended = <&vic 22 &sic 2>;
  231. clocks = <&xtal24mhz>, <&pclk>;
  232. clock-names = "mclk", "apb_pclk";
  233. };
  234. kmi@6000 {
  235. compatible = "arm,pl050", "arm,primecell";
  236. reg = <0x6000 0x1000>;
  237. interrupt-parent = <&sic>;
  238. interrupts = <3>;
  239. clocks = <&xtal24mhz>, <&pclk>;
  240. clock-names = "KMIREFCLK", "apb_pclk";
  241. };
  242. kmi@7000 {
  243. compatible = "arm,pl050", "arm,primecell";
  244. reg = <0x7000 0x1000>;
  245. interrupt-parent = <&sic>;
  246. interrupts = <4>;
  247. clocks = <&xtal24mhz>, <&pclk>;
  248. clock-names = "KMIREFCLK", "apb_pclk";
  249. };
  250. };
  251. };
  252. };