fu540-c000.dtsi 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313
  1. // SPDX-License-Identifier: (GPL-2.0 OR MIT)
  2. /* Copyright (c) 2018-2019 SiFive, Inc */
  3. /dts-v1/;
  4. #include <dt-bindings/clock/sifive-fu540-prci.h>
  5. / {
  6. #address-cells = <2>;
  7. #size-cells = <2>;
  8. compatible = "sifive,fu540-c000", "sifive,fu540";
  9. aliases {
  10. serial0 = &uart0;
  11. serial1 = &uart1;
  12. ethernet0 = &eth0;
  13. };
  14. chosen {
  15. };
  16. cpus {
  17. #address-cells = <1>;
  18. #size-cells = <0>;
  19. cpu0: cpu@0 {
  20. compatible = "sifive,e51", "sifive,rocket0", "riscv";
  21. device_type = "cpu";
  22. i-cache-block-size = <64>;
  23. i-cache-sets = <128>;
  24. i-cache-size = <16384>;
  25. reg = <0>;
  26. riscv,isa = "rv64imac";
  27. status = "disabled";
  28. cpu0_intc: interrupt-controller {
  29. #interrupt-cells = <1>;
  30. compatible = "riscv,cpu-intc";
  31. interrupt-controller;
  32. };
  33. };
  34. cpu1: cpu@1 {
  35. compatible = "sifive,u54-mc", "sifive,rocket0", "riscv";
  36. d-cache-block-size = <64>;
  37. d-cache-sets = <64>;
  38. d-cache-size = <32768>;
  39. d-tlb-sets = <1>;
  40. d-tlb-size = <32>;
  41. device_type = "cpu";
  42. i-cache-block-size = <64>;
  43. i-cache-sets = <64>;
  44. i-cache-size = <32768>;
  45. i-tlb-sets = <1>;
  46. i-tlb-size = <32>;
  47. mmu-type = "riscv,sv39";
  48. reg = <1>;
  49. riscv,isa = "rv64imafdc";
  50. tlb-split;
  51. next-level-cache = <&l2cache>;
  52. cpu1_intc: interrupt-controller {
  53. #interrupt-cells = <1>;
  54. compatible = "riscv,cpu-intc";
  55. interrupt-controller;
  56. };
  57. };
  58. cpu2: cpu@2 {
  59. compatible = "sifive,u54-mc", "sifive,rocket0", "riscv";
  60. d-cache-block-size = <64>;
  61. d-cache-sets = <64>;
  62. d-cache-size = <32768>;
  63. d-tlb-sets = <1>;
  64. d-tlb-size = <32>;
  65. device_type = "cpu";
  66. i-cache-block-size = <64>;
  67. i-cache-sets = <64>;
  68. i-cache-size = <32768>;
  69. i-tlb-sets = <1>;
  70. i-tlb-size = <32>;
  71. mmu-type = "riscv,sv39";
  72. reg = <2>;
  73. riscv,isa = "rv64imafdc";
  74. tlb-split;
  75. next-level-cache = <&l2cache>;
  76. cpu2_intc: interrupt-controller {
  77. #interrupt-cells = <1>;
  78. compatible = "riscv,cpu-intc";
  79. interrupt-controller;
  80. };
  81. };
  82. cpu3: cpu@3 {
  83. compatible = "sifive,u54-mc", "sifive,rocket0", "riscv";
  84. d-cache-block-size = <64>;
  85. d-cache-sets = <64>;
  86. d-cache-size = <32768>;
  87. d-tlb-sets = <1>;
  88. d-tlb-size = <32>;
  89. device_type = "cpu";
  90. i-cache-block-size = <64>;
  91. i-cache-sets = <64>;
  92. i-cache-size = <32768>;
  93. i-tlb-sets = <1>;
  94. i-tlb-size = <32>;
  95. mmu-type = "riscv,sv39";
  96. reg = <3>;
  97. riscv,isa = "rv64imafdc";
  98. tlb-split;
  99. next-level-cache = <&l2cache>;
  100. cpu3_intc: interrupt-controller {
  101. #interrupt-cells = <1>;
  102. compatible = "riscv,cpu-intc";
  103. interrupt-controller;
  104. };
  105. };
  106. cpu4: cpu@4 {
  107. compatible = "sifive,u54-mc", "sifive,rocket0", "riscv";
  108. d-cache-block-size = <64>;
  109. d-cache-sets = <64>;
  110. d-cache-size = <32768>;
  111. d-tlb-sets = <1>;
  112. d-tlb-size = <32>;
  113. device_type = "cpu";
  114. i-cache-block-size = <64>;
  115. i-cache-sets = <64>;
  116. i-cache-size = <32768>;
  117. i-tlb-sets = <1>;
  118. i-tlb-size = <32>;
  119. mmu-type = "riscv,sv39";
  120. reg = <4>;
  121. riscv,isa = "rv64imafdc";
  122. tlb-split;
  123. next-level-cache = <&l2cache>;
  124. cpu4_intc: interrupt-controller {
  125. #interrupt-cells = <1>;
  126. compatible = "riscv,cpu-intc";
  127. interrupt-controller;
  128. };
  129. };
  130. cpu-map {
  131. cluster0 {
  132. core0 {
  133. cpu = <&cpu0>;
  134. };
  135. core1 {
  136. cpu = <&cpu1>;
  137. };
  138. core2 {
  139. cpu = <&cpu2>;
  140. };
  141. core3 {
  142. cpu = <&cpu3>;
  143. };
  144. core4 {
  145. cpu = <&cpu4>;
  146. };
  147. };
  148. };
  149. };
  150. soc {
  151. #address-cells = <2>;
  152. #size-cells = <2>;
  153. compatible = "simple-bus";
  154. ranges;
  155. plic0: interrupt-controller@c000000 {
  156. compatible = "sifive,fu540-c000-plic", "sifive,plic-1.0.0";
  157. reg = <0x0 0xc000000 0x0 0x4000000>;
  158. #address-cells = <0>;
  159. #interrupt-cells = <1>;
  160. interrupt-controller;
  161. interrupts-extended =
  162. <&cpu0_intc 0xffffffff>,
  163. <&cpu1_intc 0xffffffff>, <&cpu1_intc 9>,
  164. <&cpu2_intc 0xffffffff>, <&cpu2_intc 9>,
  165. <&cpu3_intc 0xffffffff>, <&cpu3_intc 9>,
  166. <&cpu4_intc 0xffffffff>, <&cpu4_intc 9>;
  167. riscv,ndev = <53>;
  168. };
  169. prci: clock-controller@10000000 {
  170. compatible = "sifive,fu540-c000-prci";
  171. reg = <0x0 0x10000000 0x0 0x1000>;
  172. clocks = <&hfclk>, <&rtcclk>;
  173. #clock-cells = <1>;
  174. };
  175. uart0: serial@10010000 {
  176. compatible = "sifive,fu540-c000-uart", "sifive,uart0";
  177. reg = <0x0 0x10010000 0x0 0x1000>;
  178. interrupt-parent = <&plic0>;
  179. interrupts = <4>;
  180. clocks = <&prci FU540_PRCI_CLK_TLCLK>;
  181. status = "disabled";
  182. };
  183. dma: dma-controller@3000000 {
  184. compatible = "sifive,fu540-c000-pdma", "sifive,pdma0";
  185. reg = <0x0 0x3000000 0x0 0x8000>;
  186. interrupt-parent = <&plic0>;
  187. interrupts = <23>, <24>, <25>, <26>, <27>, <28>, <29>,
  188. <30>;
  189. dma-channels = <4>;
  190. #dma-cells = <1>;
  191. };
  192. uart1: serial@10011000 {
  193. compatible = "sifive,fu540-c000-uart", "sifive,uart0";
  194. reg = <0x0 0x10011000 0x0 0x1000>;
  195. interrupt-parent = <&plic0>;
  196. interrupts = <5>;
  197. clocks = <&prci FU540_PRCI_CLK_TLCLK>;
  198. status = "disabled";
  199. };
  200. i2c0: i2c@10030000 {
  201. compatible = "sifive,fu540-c000-i2c", "sifive,i2c0";
  202. reg = <0x0 0x10030000 0x0 0x1000>;
  203. interrupt-parent = <&plic0>;
  204. interrupts = <50>;
  205. clocks = <&prci FU540_PRCI_CLK_TLCLK>;
  206. reg-shift = <2>;
  207. reg-io-width = <1>;
  208. #address-cells = <1>;
  209. #size-cells = <0>;
  210. status = "disabled";
  211. };
  212. qspi0: spi@10040000 {
  213. compatible = "sifive,fu540-c000-spi", "sifive,spi0";
  214. reg = <0x0 0x10040000 0x0 0x1000>,
  215. <0x0 0x20000000 0x0 0x10000000>;
  216. interrupt-parent = <&plic0>;
  217. interrupts = <51>;
  218. clocks = <&prci FU540_PRCI_CLK_TLCLK>;
  219. #address-cells = <1>;
  220. #size-cells = <0>;
  221. status = "disabled";
  222. };
  223. qspi1: spi@10041000 {
  224. compatible = "sifive,fu540-c000-spi", "sifive,spi0";
  225. reg = <0x0 0x10041000 0x0 0x1000>,
  226. <0x0 0x30000000 0x0 0x10000000>;
  227. interrupt-parent = <&plic0>;
  228. interrupts = <52>;
  229. clocks = <&prci FU540_PRCI_CLK_TLCLK>;
  230. #address-cells = <1>;
  231. #size-cells = <0>;
  232. status = "disabled";
  233. };
  234. qspi2: spi@10050000 {
  235. compatible = "sifive,fu540-c000-spi", "sifive,spi0";
  236. reg = <0x0 0x10050000 0x0 0x1000>;
  237. interrupt-parent = <&plic0>;
  238. interrupts = <6>;
  239. clocks = <&prci FU540_PRCI_CLK_TLCLK>;
  240. #address-cells = <1>;
  241. #size-cells = <0>;
  242. status = "disabled";
  243. };
  244. eth0: ethernet@10090000 {
  245. compatible = "sifive,fu540-c000-gem";
  246. interrupt-parent = <&plic0>;
  247. interrupts = <53>;
  248. reg = <0x0 0x10090000 0x0 0x2000>,
  249. <0x0 0x100a0000 0x0 0x1000>;
  250. local-mac-address = [00 00 00 00 00 00];
  251. clock-names = "pclk", "hclk";
  252. clocks = <&prci FU540_PRCI_CLK_GEMGXLPLL>,
  253. <&prci FU540_PRCI_CLK_GEMGXLPLL>;
  254. #address-cells = <1>;
  255. #size-cells = <0>;
  256. status = "disabled";
  257. };
  258. pwm0: pwm@10020000 {
  259. compatible = "sifive,fu540-c000-pwm", "sifive,pwm0";
  260. reg = <0x0 0x10020000 0x0 0x1000>;
  261. interrupt-parent = <&plic0>;
  262. interrupts = <42>, <43>, <44>, <45>;
  263. clocks = <&prci FU540_PRCI_CLK_TLCLK>;
  264. #pwm-cells = <3>;
  265. status = "disabled";
  266. };
  267. pwm1: pwm@10021000 {
  268. compatible = "sifive,fu540-c000-pwm", "sifive,pwm0";
  269. reg = <0x0 0x10021000 0x0 0x1000>;
  270. interrupt-parent = <&plic0>;
  271. interrupts = <46>, <47>, <48>, <49>;
  272. clocks = <&prci FU540_PRCI_CLK_TLCLK>;
  273. #pwm-cells = <3>;
  274. status = "disabled";
  275. };
  276. l2cache: cache-controller@2010000 {
  277. compatible = "sifive,fu540-c000-ccache", "cache";
  278. cache-block-size = <64>;
  279. cache-level = <2>;
  280. cache-sets = <1024>;
  281. cache-size = <2097152>;
  282. cache-unified;
  283. interrupt-parent = <&plic0>;
  284. interrupts = <1>, <2>, <3>;
  285. reg = <0x0 0x2010000 0x0 0x1000>;
  286. };
  287. gpio: gpio@10060000 {
  288. compatible = "sifive,fu540-c000-gpio", "sifive,gpio0";
  289. interrupt-parent = <&plic0>;
  290. interrupts = <7>, <8>, <9>, <10>, <11>, <12>, <13>,
  291. <14>, <15>, <16>, <17>, <18>, <19>, <20>,
  292. <21>, <22>;
  293. reg = <0x0 0x10060000 0x0 0x1000>;
  294. gpio-controller;
  295. #gpio-cells = <2>;
  296. interrupt-controller;
  297. #interrupt-cells = <2>;
  298. clocks = <&prci FU540_PRCI_CLK_TLCLK>;
  299. status = "disabled";
  300. };
  301. };
  302. };