amd-seattle-soc.dtsi 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * DTS file for AMD Seattle SoC
  4. *
  5. * Copyright (C) 2014 Advanced Micro Devices, Inc.
  6. */
  7. / {
  8. compatible = "amd,seattle";
  9. interrupt-parent = <&gic0>;
  10. #address-cells = <2>;
  11. #size-cells = <2>;
  12. gic0: interrupt-controller@e1101000 {
  13. compatible = "arm,gic-400", "arm,cortex-a15-gic";
  14. interrupt-controller;
  15. #interrupt-cells = <3>;
  16. #address-cells = <2>;
  17. #size-cells = <2>;
  18. reg = <0x0 0xe1110000 0 0x1000>,
  19. <0x0 0xe112f000 0 0x2000>,
  20. <0x0 0xe1140000 0 0x2000>,
  21. <0x0 0xe1160000 0 0x2000>;
  22. interrupts = <1 9 0xf04>;
  23. ranges = <0 0 0 0xe1100000 0 0x100000>;
  24. v2m0: v2m@e0080000 {
  25. compatible = "arm,gic-v2m-frame";
  26. msi-controller;
  27. reg = <0x0 0x00080000 0 0x1000>;
  28. };
  29. };
  30. timer {
  31. compatible = "arm,armv8-timer";
  32. interrupts = <1 13 0xff04>,
  33. <1 14 0xff04>,
  34. <1 11 0xff04>,
  35. <1 10 0xff04>;
  36. };
  37. smb0: smb {
  38. compatible = "simple-bus";
  39. #address-cells = <2>;
  40. #size-cells = <2>;
  41. ranges;
  42. /*
  43. * dma-ranges is 40-bit address space containing:
  44. * - GICv2m MSI register is at 0xe0080000
  45. * - DRAM range [0x8000000000 to 0xffffffffff]
  46. */
  47. dma-ranges = <0x0 0x0 0x0 0x0 0x100 0x0>;
  48. /include/ "amd-seattle-clks.dtsi"
  49. sata0: sata@e0300000 {
  50. compatible = "snps,dwc-ahci";
  51. reg = <0 0xe0300000 0 0xf0000>;
  52. interrupts = <0 355 4>;
  53. clocks = <&sataclk_333mhz>;
  54. iommus = <&sata0_smmu 0x0 0x1f>;
  55. dma-coherent;
  56. };
  57. /* This is for Rev B only */
  58. sata1: sata@e0d00000 {
  59. status = "disabled";
  60. compatible = "snps,dwc-ahci";
  61. reg = <0 0xe0d00000 0 0xf0000>;
  62. interrupts = <0 354 4>;
  63. clocks = <&sataclk_333mhz>;
  64. iommus = <&sata1_smmu 0x0e>,
  65. <&sata1_smmu 0x0f>,
  66. <&sata1_smmu 0x1e>;
  67. dma-coherent;
  68. };
  69. sata0_smmu: iommu@e0200000 {
  70. compatible = "arm,mmu-401";
  71. reg = <0 0xe0200000 0 0x10000>;
  72. #global-interrupts = <1>;
  73. interrupts = <0 332 4>, <0 332 4>;
  74. #iommu-cells = <2>;
  75. dma-coherent;
  76. };
  77. sata1_smmu: iommu@e0c00000 {
  78. compatible = "arm,mmu-401";
  79. reg = <0 0xe0c00000 0 0x10000>;
  80. #global-interrupts = <1>;
  81. interrupts = <0 331 4>, <0 331 4>;
  82. #iommu-cells = <1>;
  83. dma-coherent;
  84. };
  85. i2c0: i2c@e1000000 {
  86. status = "disabled";
  87. compatible = "snps,designware-i2c";
  88. reg = <0 0xe1000000 0 0x1000>;
  89. interrupts = <0 357 4>;
  90. clocks = <&miscclk_250mhz>;
  91. };
  92. i2c1: i2c@e0050000 {
  93. status = "disabled";
  94. compatible = "snps,designware-i2c";
  95. reg = <0 0xe0050000 0 0x1000>;
  96. interrupts = <0 340 4>;
  97. clocks = <&miscclk_250mhz>;
  98. };
  99. serial0: serial@e1010000 {
  100. compatible = "arm,pl011", "arm,primecell";
  101. reg = <0 0xe1010000 0 0x1000>;
  102. interrupts = <0 328 4>;
  103. clocks = <&uartspiclk_100mhz>, <&uartspiclk_100mhz>;
  104. clock-names = "uartclk", "apb_pclk";
  105. };
  106. spi0: spi@e1020000 {
  107. status = "disabled";
  108. compatible = "arm,pl022", "arm,primecell";
  109. reg = <0 0xe1020000 0 0x1000>;
  110. spi-controller;
  111. interrupts = <0 330 4>;
  112. clocks = <&uartspiclk_100mhz>;
  113. clock-names = "apb_pclk";
  114. };
  115. spi1: spi@e1030000 {
  116. status = "disabled";
  117. compatible = "arm,pl022", "arm,primecell";
  118. reg = <0 0xe1030000 0 0x1000>;
  119. spi-controller;
  120. interrupts = <0 329 4>;
  121. clocks = <&uartspiclk_100mhz>;
  122. clock-names = "apb_pclk";
  123. num-cs = <1>;
  124. #address-cells = <1>;
  125. #size-cells = <0>;
  126. };
  127. gpio0: gpio@e1040000 { /* Not available to OS for B0 */
  128. status = "disabled";
  129. compatible = "arm,pl061", "arm,primecell";
  130. #gpio-cells = <2>;
  131. reg = <0 0xe1040000 0 0x1000>;
  132. gpio-controller;
  133. interrupts = <0 359 4>;
  134. interrupt-controller;
  135. #interrupt-cells = <2>;
  136. clocks = <&miscclk_250mhz>;
  137. clock-names = "apb_pclk";
  138. };
  139. gpio1: gpio@e1050000 { /* [0:7] */
  140. status = "disabled";
  141. compatible = "arm,pl061", "arm,primecell";
  142. #gpio-cells = <2>;
  143. reg = <0 0xe1050000 0 0x1000>;
  144. gpio-controller;
  145. interrupt-controller;
  146. #interrupt-cells = <2>;
  147. interrupts = <0 358 4>;
  148. clocks = <&miscclk_250mhz>;
  149. clock-names = "apb_pclk";
  150. };
  151. gpio2: gpio@e0020000 { /* [8:15] */
  152. status = "disabled";
  153. compatible = "arm,pl061", "arm,primecell";
  154. #gpio-cells = <2>;
  155. reg = <0 0xe0020000 0 0x1000>;
  156. gpio-controller;
  157. interrupt-controller;
  158. #interrupt-cells = <2>;
  159. interrupts = <0 366 4>;
  160. clocks = <&miscclk_250mhz>;
  161. clock-names = "apb_pclk";
  162. };
  163. gpio3: gpio@e0030000 { /* [16:23] */
  164. status = "disabled";
  165. compatible = "arm,pl061", "arm,primecell";
  166. #gpio-cells = <2>;
  167. reg = <0 0xe0030000 0 0x1000>;
  168. gpio-controller;
  169. interrupt-controller;
  170. #interrupt-cells = <2>;
  171. interrupts = <0 365 4>;
  172. clocks = <&miscclk_250mhz>;
  173. clock-names = "apb_pclk";
  174. };
  175. gpio4: gpio@e0080000 { /* [24] */
  176. status = "disabled";
  177. compatible = "arm,pl061", "arm,primecell";
  178. #gpio-cells = <2>;
  179. reg = <0 0xe0080000 0 0x1000>;
  180. gpio-controller;
  181. interrupt-controller;
  182. #interrupt-cells = <2>;
  183. interrupts = <0 361 4>;
  184. clocks = <&miscclk_250mhz>;
  185. clock-names = "apb_pclk";
  186. };
  187. ccp0: ccp@e0100000 {
  188. status = "disabled";
  189. compatible = "amd,ccp-seattle-v1a";
  190. reg = <0 0xe0100000 0 0x10000>;
  191. interrupts = <0 3 4>;
  192. dma-coherent;
  193. iommus = <&sata1_smmu 0x00>,
  194. <&sata1_smmu 0x02>,
  195. <&sata1_smmu 0x40>,
  196. <&sata1_smmu 0x42>;
  197. };
  198. pcie0: pcie@f0000000 {
  199. compatible = "pci-host-ecam-generic";
  200. #address-cells = <3>;
  201. #size-cells = <2>;
  202. #interrupt-cells = <1>;
  203. device_type = "pci";
  204. bus-range = <0 0x7f>;
  205. msi-parent = <&v2m0>;
  206. reg = <0 0xf0000000 0 0x10000000>;
  207. interrupt-map-mask = <0xff00 0x0 0x0 0x7>;
  208. interrupt-map =
  209. <0x1100 0x0 0x0 0x1 &gic0 0x0 0x0 0x0 0x120 0x1>,
  210. <0x1100 0x0 0x0 0x2 &gic0 0x0 0x0 0x0 0x121 0x1>,
  211. <0x1100 0x0 0x0 0x3 &gic0 0x0 0x0 0x0 0x122 0x1>,
  212. <0x1100 0x0 0x0 0x4 &gic0 0x0 0x0 0x0 0x123 0x1>,
  213. <0x1200 0x0 0x0 0x1 &gic0 0x0 0x0 0x0 0x124 0x1>,
  214. <0x1200 0x0 0x0 0x2 &gic0 0x0 0x0 0x0 0x125 0x1>,
  215. <0x1200 0x0 0x0 0x3 &gic0 0x0 0x0 0x0 0x126 0x1>,
  216. <0x1200 0x0 0x0 0x4 &gic0 0x0 0x0 0x0 0x127 0x1>,
  217. <0x1300 0x0 0x0 0x1 &gic0 0x0 0x0 0x0 0x128 0x1>,
  218. <0x1300 0x0 0x0 0x2 &gic0 0x0 0x0 0x0 0x129 0x1>,
  219. <0x1300 0x0 0x0 0x3 &gic0 0x0 0x0 0x0 0x12a 0x1>,
  220. <0x1300 0x0 0x0 0x4 &gic0 0x0 0x0 0x0 0x12b 0x1>;
  221. dma-coherent;
  222. dma-ranges = <0x43000000 0x0 0x0 0x0 0x0 0x100 0x0>;
  223. ranges =
  224. /* I/O Memory (size=64K) */
  225. <0x01000000 0x00 0x00000000 0x00 0xefff0000 0x00 0x00010000>,
  226. /* 32-bit MMIO (size=2G) */
  227. <0x02000000 0x00 0x40000000 0x00 0x40000000 0x00 0x80000000>,
  228. /* 64-bit MMIO (size= 508G) */
  229. <0x03000000 0x01 0x00000000 0x01 0x00000000 0x7f 0x00000000>;
  230. iommu-map = <0x0 &pcie_smmu 0x0 0x10000>;
  231. };
  232. pcie_smmu: iommu@e0a00000 {
  233. compatible = "arm,mmu-401";
  234. reg = <0 0xe0a00000 0 0x10000>;
  235. #global-interrupts = <1>;
  236. interrupts = <0 333 4>, <0 333 4>;
  237. #iommu-cells = <1>;
  238. dma-coherent;
  239. };
  240. /* Perf CCN504 PMU */
  241. ccn: ccn@e8000000 {
  242. compatible = "arm,ccn-504";
  243. reg = <0x0 0xe8000000 0 0x1000000>;
  244. interrupts = <0 380 4>;
  245. };
  246. ipmi_kcs: kcs@e0010000 {
  247. status = "disabled";
  248. compatible = "ipmi-kcs";
  249. device_type = "ipmi";
  250. reg = <0x0 0xe0010000 0 0x8>;
  251. interrupts = <0 389 4>;
  252. reg-size = <1>;
  253. reg-spacing = <4>;
  254. };
  255. };
  256. };