rtsm_ve-motherboard.dtsi 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. /*
  2. * ARM Ltd. Fast Models
  3. *
  4. * Versatile Express (VE) system model
  5. * Motherboard component
  6. *
  7. * VEMotherBoard.lisa
  8. */
  9. motherboard {
  10. arm,v2m-memory-map = "rs1";
  11. compatible = "arm,vexpress,v2m-p1", "simple-bus";
  12. #address-cells = <2>; /* SMB chipselect number and offset */
  13. #size-cells = <1>;
  14. #interrupt-cells = <1>;
  15. ranges;
  16. flash@0,00000000 {
  17. compatible = "arm,vexpress-flash", "cfi-flash";
  18. reg = <0 0x00000000 0x04000000>,
  19. <4 0x00000000 0x04000000>;
  20. bank-width = <4>;
  21. };
  22. vram@2,00000000 {
  23. compatible = "arm,vexpress-vram";
  24. reg = <2 0x00000000 0x00800000>;
  25. };
  26. ethernet@2,02000000 {
  27. compatible = "smsc,lan91c111";
  28. reg = <2 0x02000000 0x10000>;
  29. interrupts = <15>;
  30. };
  31. v2m_clk24mhz: clk24mhz {
  32. compatible = "fixed-clock";
  33. #clock-cells = <0>;
  34. clock-frequency = <24000000>;
  35. clock-output-names = "v2m:clk24mhz";
  36. };
  37. v2m_refclk1mhz: refclk1mhz {
  38. compatible = "fixed-clock";
  39. #clock-cells = <0>;
  40. clock-frequency = <1000000>;
  41. clock-output-names = "v2m:refclk1mhz";
  42. };
  43. v2m_refclk32khz: refclk32khz {
  44. compatible = "fixed-clock";
  45. #clock-cells = <0>;
  46. clock-frequency = <32768>;
  47. clock-output-names = "v2m:refclk32khz";
  48. };
  49. iofpga@3,00000000 {
  50. compatible = "arm,amba-bus", "simple-bus";
  51. #address-cells = <1>;
  52. #size-cells = <1>;
  53. ranges = <0 3 0 0x200000>;
  54. v2m_sysreg: sysreg@010000 {
  55. compatible = "arm,vexpress-sysreg";
  56. reg = <0x010000 0x1000>;
  57. gpio-controller;
  58. #gpio-cells = <2>;
  59. };
  60. v2m_sysctl: sysctl@020000 {
  61. compatible = "arm,sp810", "arm,primecell";
  62. reg = <0x020000 0x1000>;
  63. clocks = <&v2m_refclk32khz>, <&v2m_refclk1mhz>, <&v2m_clk24mhz>;
  64. clock-names = "refclk", "timclk", "apb_pclk";
  65. #clock-cells = <1>;
  66. clock-output-names = "timerclken0", "timerclken1", "timerclken2", "timerclken3";
  67. };
  68. aaci@040000 {
  69. compatible = "arm,pl041", "arm,primecell";
  70. reg = <0x040000 0x1000>;
  71. interrupts = <11>;
  72. clocks = <&v2m_clk24mhz>;
  73. clock-names = "apb_pclk";
  74. };
  75. mmci@050000 {
  76. compatible = "arm,pl180", "arm,primecell";
  77. reg = <0x050000 0x1000>;
  78. interrupts = <9 10>;
  79. cd-gpios = <&v2m_sysreg 0 0>;
  80. wp-gpios = <&v2m_sysreg 1 0>;
  81. max-frequency = <12000000>;
  82. vmmc-supply = <&v2m_fixed_3v3>;
  83. clocks = <&v2m_clk24mhz>, <&v2m_clk24mhz>;
  84. clock-names = "mclk", "apb_pclk";
  85. };
  86. kmi@060000 {
  87. compatible = "arm,pl050", "arm,primecell";
  88. reg = <0x060000 0x1000>;
  89. interrupts = <12>;
  90. clocks = <&v2m_clk24mhz>, <&v2m_clk24mhz>;
  91. clock-names = "KMIREFCLK", "apb_pclk";
  92. };
  93. kmi@070000 {
  94. compatible = "arm,pl050", "arm,primecell";
  95. reg = <0x070000 0x1000>;
  96. interrupts = <13>;
  97. clocks = <&v2m_clk24mhz>, <&v2m_clk24mhz>;
  98. clock-names = "KMIREFCLK", "apb_pclk";
  99. };
  100. v2m_serial0: uart@090000 {
  101. compatible = "arm,pl011", "arm,primecell";
  102. reg = <0x090000 0x1000>;
  103. interrupts = <5>;
  104. clocks = <&v2m_clk24mhz>, <&v2m_clk24mhz>;
  105. clock-names = "uartclk", "apb_pclk";
  106. };
  107. v2m_serial1: uart@0a0000 {
  108. compatible = "arm,pl011", "arm,primecell";
  109. reg = <0x0a0000 0x1000>;
  110. interrupts = <6>;
  111. clocks = <&v2m_clk24mhz>, <&v2m_clk24mhz>;
  112. clock-names = "uartclk", "apb_pclk";
  113. };
  114. v2m_serial2: uart@0b0000 {
  115. compatible = "arm,pl011", "arm,primecell";
  116. reg = <0x0b0000 0x1000>;
  117. interrupts = <7>;
  118. clocks = <&v2m_clk24mhz>, <&v2m_clk24mhz>;
  119. clock-names = "uartclk", "apb_pclk";
  120. };
  121. v2m_serial3: uart@0c0000 {
  122. compatible = "arm,pl011", "arm,primecell";
  123. reg = <0x0c0000 0x1000>;
  124. interrupts = <8>;
  125. clocks = <&v2m_clk24mhz>, <&v2m_clk24mhz>;
  126. clock-names = "uartclk", "apb_pclk";
  127. };
  128. wdt@0f0000 {
  129. compatible = "arm,sp805", "arm,primecell";
  130. reg = <0x0f0000 0x1000>;
  131. interrupts = <0>;
  132. clocks = <&v2m_refclk32khz>, <&v2m_clk24mhz>;
  133. clock-names = "wdogclk", "apb_pclk";
  134. };
  135. v2m_timer01: timer@110000 {
  136. compatible = "arm,sp804", "arm,primecell";
  137. reg = <0x110000 0x1000>;
  138. interrupts = <2>;
  139. clocks = <&v2m_sysctl 0>, <&v2m_sysctl 1>, <&v2m_clk24mhz>;
  140. clock-names = "timclken1", "timclken2", "apb_pclk";
  141. };
  142. v2m_timer23: timer@120000 {
  143. compatible = "arm,sp804", "arm,primecell";
  144. reg = <0x120000 0x1000>;
  145. interrupts = <3>;
  146. clocks = <&v2m_sysctl 2>, <&v2m_sysctl 3>, <&v2m_clk24mhz>;
  147. clock-names = "timclken1", "timclken2", "apb_pclk";
  148. };
  149. rtc@170000 {
  150. compatible = "arm,pl031", "arm,primecell";
  151. reg = <0x170000 0x1000>;
  152. interrupts = <4>;
  153. clocks = <&v2m_clk24mhz>;
  154. clock-names = "apb_pclk";
  155. };
  156. clcd@1f0000 {
  157. compatible = "arm,pl111", "arm,primecell";
  158. reg = <0x1f0000 0x1000>;
  159. interrupts = <14>;
  160. clocks = <&v2m_oscclk1>, <&v2m_clk24mhz>;
  161. clock-names = "clcdclk", "apb_pclk";
  162. };
  163. };
  164. v2m_fixed_3v3: fixedregulator@0 {
  165. compatible = "regulator-fixed";
  166. regulator-name = "3V3";
  167. regulator-min-microvolt = <3300000>;
  168. regulator-max-microvolt = <3300000>;
  169. regulator-always-on;
  170. };
  171. mcc {
  172. compatible = "arm,vexpress,config-bus", "simple-bus";
  173. arm,vexpress,config-bridge = <&v2m_sysreg>;
  174. v2m_oscclk1: osc@1 {
  175. /* CLCD clock */
  176. compatible = "arm,vexpress-osc";
  177. arm,vexpress-sysreg,func = <1 1>;
  178. freq-range = <23750000 63500000>;
  179. #clock-cells = <0>;
  180. clock-output-names = "v2m:oscclk1";
  181. };
  182. reset@0 {
  183. compatible = "arm,vexpress-reset";
  184. arm,vexpress-sysreg,func = <5 0>;
  185. };
  186. muxfpga@0 {
  187. compatible = "arm,vexpress-muxfpga";
  188. arm,vexpress-sysreg,func = <7 0>;
  189. };
  190. shutdown@0 {
  191. compatible = "arm,vexpress-shutdown";
  192. arm,vexpress-sysreg,func = <8 0>;
  193. };
  194. reboot@0 {
  195. compatible = "arm,vexpress-reboot";
  196. arm,vexpress-sysreg,func = <9 0>;
  197. };
  198. dvimode@0 {
  199. compatible = "arm,vexpress-dvimode";
  200. arm,vexpress-sysreg,func = <11 0>;
  201. };
  202. };
  203. };