highbank.dts 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. /*
  2. * Copyright 2011 Calxeda, Inc.
  3. *
  4. * This program is free software; you can redistribute it and/or modify it
  5. * under the terms and conditions of the GNU General Public License,
  6. * version 2, as published by the Free Software Foundation.
  7. *
  8. * This program is distributed in the hope it will be useful, but WITHOUT
  9. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  10. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  11. * more details.
  12. *
  13. * You should have received a copy of the GNU General Public License along with
  14. * this program. If not, see <http://www.gnu.org/licenses/>.
  15. */
  16. /dts-v1/;
  17. /* First 4KB has pen for secondary cores. */
  18. /memreserve/ 0x00000000 0x0001000;
  19. / {
  20. model = "Calxeda Highbank";
  21. compatible = "calxeda,highbank";
  22. #address-cells = <1>;
  23. #size-cells = <1>;
  24. cpus {
  25. #address-cells = <1>;
  26. #size-cells = <0>;
  27. cpu@0 {
  28. compatible = "arm,cortex-a9";
  29. reg = <0>;
  30. next-level-cache = <&L2>;
  31. };
  32. cpu@1 {
  33. compatible = "arm,cortex-a9";
  34. reg = <1>;
  35. next-level-cache = <&L2>;
  36. };
  37. cpu@2 {
  38. compatible = "arm,cortex-a9";
  39. reg = <2>;
  40. next-level-cache = <&L2>;
  41. };
  42. cpu@3 {
  43. compatible = "arm,cortex-a9";
  44. reg = <3>;
  45. next-level-cache = <&L2>;
  46. };
  47. };
  48. memory {
  49. name = "memory";
  50. device_type = "memory";
  51. reg = <0x00000000 0xff900000>;
  52. };
  53. chosen {
  54. bootargs = "console=ttyAMA0";
  55. };
  56. soc {
  57. #address-cells = <1>;
  58. #size-cells = <1>;
  59. compatible = "simple-bus";
  60. interrupt-parent = <&intc>;
  61. ranges;
  62. timer@fff10600 {
  63. compatible = "arm,cortex-a9-twd-timer";
  64. reg = <0xfff10600 0x20>;
  65. interrupts = <1 13 0xf01>;
  66. };
  67. watchdog@fff10620 {
  68. compatible = "arm,cortex-a9-twd-wdt";
  69. reg = <0xfff10620 0x20>;
  70. interrupts = <1 14 0xf01>;
  71. };
  72. intc: interrupt-controller@fff11000 {
  73. compatible = "arm,cortex-a9-gic";
  74. #interrupt-cells = <3>;
  75. #size-cells = <0>;
  76. #address-cells = <1>;
  77. interrupt-controller;
  78. reg = <0xfff11000 0x1000>,
  79. <0xfff10100 0x100>;
  80. };
  81. L2: l2-cache {
  82. compatible = "arm,pl310-cache";
  83. reg = <0xfff12000 0x1000>;
  84. interrupts = <0 70 4>;
  85. cache-unified;
  86. cache-level = <2>;
  87. };
  88. pmu {
  89. compatible = "arm,cortex-a9-pmu";
  90. interrupts = <0 76 4 0 75 4 0 74 4 0 73 4>;
  91. };
  92. sata@ffe08000 {
  93. compatible = "calxeda,hb-ahci";
  94. reg = <0xffe08000 0x10000>;
  95. interrupts = <0 83 4>;
  96. };
  97. sdhci@ffe0e000 {
  98. compatible = "calxeda,hb-sdhci";
  99. reg = <0xffe0e000 0x1000>;
  100. interrupts = <0 90 4>;
  101. };
  102. memory-controller@fff00000 {
  103. compatible = "calxeda,hb-ddr-ctrl";
  104. reg = <0xfff00000 0x1000>;
  105. interrupts = <0 91 4>;
  106. };
  107. ipc@fff20000 {
  108. compatible = "arm,pl320", "arm,primecell";
  109. reg = <0xfff20000 0x1000>;
  110. interrupts = <0 7 4>;
  111. };
  112. gpioe: gpio@fff30000 {
  113. #gpio-cells = <2>;
  114. compatible = "arm,pl061", "arm,primecell";
  115. gpio-controller;
  116. reg = <0xfff30000 0x1000>;
  117. interrupts = <0 14 4>;
  118. };
  119. gpiof: gpio@fff31000 {
  120. #gpio-cells = <2>;
  121. compatible = "arm,pl061", "arm,primecell";
  122. gpio-controller;
  123. reg = <0xfff31000 0x1000>;
  124. interrupts = <0 15 4>;
  125. };
  126. gpiog: gpio@fff32000 {
  127. #gpio-cells = <2>;
  128. compatible = "arm,pl061", "arm,primecell";
  129. gpio-controller;
  130. reg = <0xfff32000 0x1000>;
  131. interrupts = <0 16 4>;
  132. };
  133. gpioh: gpio@fff33000 {
  134. #gpio-cells = <2>;
  135. compatible = "arm,pl061", "arm,primecell";
  136. gpio-controller;
  137. reg = <0xfff33000 0x1000>;
  138. interrupts = <0 17 4>;
  139. };
  140. timer {
  141. compatible = "arm,sp804", "arm,primecell";
  142. reg = <0xfff34000 0x1000>;
  143. interrupts = <0 18 4>;
  144. };
  145. rtc@fff35000 {
  146. compatible = "arm,pl031", "arm,primecell";
  147. reg = <0xfff35000 0x1000>;
  148. interrupts = <0 19 4>;
  149. };
  150. serial@fff36000 {
  151. compatible = "arm,pl011", "arm,primecell";
  152. reg = <0xfff36000 0x1000>;
  153. interrupts = <0 20 4>;
  154. };
  155. smic@fff3a000 {
  156. compatible = "ipmi-smic";
  157. device_type = "ipmi";
  158. reg = <0xfff3a000 0x1000>;
  159. interrupts = <0 24 4>;
  160. reg-size = <4>;
  161. reg-spacing = <4>;
  162. };
  163. sregs@fff3c000 {
  164. compatible = "calxeda,hb-sregs";
  165. reg = <0xfff3c000 0x1000>;
  166. };
  167. sregs@fff3c200 {
  168. compatible = "calxeda,hb-sregs-l2-ecc";
  169. reg = <0xfff3c200 0x100>;
  170. interrupts = <0 71 4 0 72 4>;
  171. };
  172. dma@fff3d000 {
  173. compatible = "arm,pl330", "arm,primecell";
  174. reg = <0xfff3d000 0x1000>;
  175. interrupts = <0 92 4>;
  176. };
  177. ethernet@fff50000 {
  178. compatible = "calxeda,hb-xgmac";
  179. reg = <0xfff50000 0x1000>;
  180. interrupts = <0 77 4 0 78 4 0 79 4>;
  181. };
  182. ethernet@fff51000 {
  183. compatible = "calxeda,hb-xgmac";
  184. reg = <0xfff51000 0x1000>;
  185. interrupts = <0 80 4 0 81 4 0 82 4>;
  186. };
  187. };
  188. };