armada-xp-mv78460.dtsi 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453
  1. // SPDX-License-Identifier: (GPL-2.0+ OR MIT)
  2. /*
  3. * Device Tree Include file for Marvell Armada XP family SoC
  4. *
  5. * Copyright (C) 2012 Marvell
  6. *
  7. * Thomas Petazzoni <[email protected]>
  8. *
  9. * Contains definitions specific to the Armada XP MV78460 SoC that are not
  10. * common to all Armada XP SoCs.
  11. */
  12. #include "armada-xp.dtsi"
  13. / {
  14. model = "Marvell Armada XP MV78460 SoC";
  15. compatible = "marvell,armadaxp-mv78460", "marvell,armadaxp", "marvell,armada-370-xp";
  16. aliases {
  17. gpio0 = &gpio0;
  18. gpio1 = &gpio1;
  19. gpio2 = &gpio2;
  20. };
  21. cpus {
  22. #address-cells = <1>;
  23. #size-cells = <0>;
  24. enable-method = "marvell,armada-xp-smp";
  25. cpu@0 {
  26. device_type = "cpu";
  27. compatible = "marvell,sheeva-v7";
  28. reg = <0>;
  29. clocks = <&cpuclk 0>;
  30. clock-latency = <1000000>;
  31. };
  32. cpu@1 {
  33. device_type = "cpu";
  34. compatible = "marvell,sheeva-v7";
  35. reg = <1>;
  36. clocks = <&cpuclk 1>;
  37. clock-latency = <1000000>;
  38. };
  39. cpu@2 {
  40. device_type = "cpu";
  41. compatible = "marvell,sheeva-v7";
  42. reg = <2>;
  43. clocks = <&cpuclk 2>;
  44. clock-latency = <1000000>;
  45. };
  46. cpu@3 {
  47. device_type = "cpu";
  48. compatible = "marvell,sheeva-v7";
  49. reg = <3>;
  50. clocks = <&cpuclk 3>;
  51. clock-latency = <1000000>;
  52. };
  53. };
  54. soc {
  55. /*
  56. * MV78460 has 4 PCIe units Gen2.0: Two units can be
  57. * configured as x4 or quad x1 lanes. Two units are
  58. * x4/x1.
  59. */
  60. pciec: pcie@82000000 {
  61. compatible = "marvell,armada-xp-pcie";
  62. status = "disabled";
  63. device_type = "pci";
  64. #address-cells = <3>;
  65. #size-cells = <2>;
  66. msi-parent = <&mpic>;
  67. bus-range = <0x00 0xff>;
  68. ranges =
  69. <0x82000000 0 0x40000 MBUS_ID(0xf0, 0x01) 0x40000 0 0x00002000 /* Port 0.0 registers */
  70. 0x82000000 0 0x42000 MBUS_ID(0xf0, 0x01) 0x42000 0 0x00002000 /* Port 2.0 registers */
  71. 0x82000000 0 0x44000 MBUS_ID(0xf0, 0x01) 0x44000 0 0x00002000 /* Port 0.1 registers */
  72. 0x82000000 0 0x48000 MBUS_ID(0xf0, 0x01) 0x48000 0 0x00002000 /* Port 0.2 registers */
  73. 0x82000000 0 0x4c000 MBUS_ID(0xf0, 0x01) 0x4c000 0 0x00002000 /* Port 0.3 registers */
  74. 0x82000000 0 0x80000 MBUS_ID(0xf0, 0x01) 0x80000 0 0x00002000 /* Port 1.0 registers */
  75. 0x82000000 0 0x82000 MBUS_ID(0xf0, 0x01) 0x82000 0 0x00002000 /* Port 3.0 registers */
  76. 0x82000000 0 0x84000 MBUS_ID(0xf0, 0x01) 0x84000 0 0x00002000 /* Port 1.1 registers */
  77. 0x82000000 0 0x88000 MBUS_ID(0xf0, 0x01) 0x88000 0 0x00002000 /* Port 1.2 registers */
  78. 0x82000000 0 0x8c000 MBUS_ID(0xf0, 0x01) 0x8c000 0 0x00002000 /* Port 1.3 registers */
  79. 0x82000000 0x1 0 MBUS_ID(0x04, 0xe8) 0 1 0 /* Port 0.0 MEM */
  80. 0x81000000 0x1 0 MBUS_ID(0x04, 0xe0) 0 1 0 /* Port 0.0 IO */
  81. 0x82000000 0x2 0 MBUS_ID(0x04, 0xd8) 0 1 0 /* Port 0.1 MEM */
  82. 0x81000000 0x2 0 MBUS_ID(0x04, 0xd0) 0 1 0 /* Port 0.1 IO */
  83. 0x82000000 0x3 0 MBUS_ID(0x04, 0xb8) 0 1 0 /* Port 0.2 MEM */
  84. 0x81000000 0x3 0 MBUS_ID(0x04, 0xb0) 0 1 0 /* Port 0.2 IO */
  85. 0x82000000 0x4 0 MBUS_ID(0x04, 0x78) 0 1 0 /* Port 0.3 MEM */
  86. 0x81000000 0x4 0 MBUS_ID(0x04, 0x70) 0 1 0 /* Port 0.3 IO */
  87. 0x82000000 0x5 0 MBUS_ID(0x08, 0xe8) 0 1 0 /* Port 1.0 MEM */
  88. 0x81000000 0x5 0 MBUS_ID(0x08, 0xe0) 0 1 0 /* Port 1.0 IO */
  89. 0x82000000 0x6 0 MBUS_ID(0x08, 0xd8) 0 1 0 /* Port 1.1 MEM */
  90. 0x81000000 0x6 0 MBUS_ID(0x08, 0xd0) 0 1 0 /* Port 1.1 IO */
  91. 0x82000000 0x7 0 MBUS_ID(0x08, 0xb8) 0 1 0 /* Port 1.2 MEM */
  92. 0x81000000 0x7 0 MBUS_ID(0x08, 0xb0) 0 1 0 /* Port 1.2 IO */
  93. 0x82000000 0x8 0 MBUS_ID(0x08, 0x78) 0 1 0 /* Port 1.3 MEM */
  94. 0x81000000 0x8 0 MBUS_ID(0x08, 0x70) 0 1 0 /* Port 1.3 IO */
  95. 0x82000000 0x9 0 MBUS_ID(0x04, 0xf8) 0 1 0 /* Port 2.0 MEM */
  96. 0x81000000 0x9 0 MBUS_ID(0x04, 0xf0) 0 1 0 /* Port 2.0 IO */
  97. 0x82000000 0xa 0 MBUS_ID(0x08, 0xf8) 0 1 0 /* Port 3.0 MEM */
  98. 0x81000000 0xa 0 MBUS_ID(0x08, 0xf0) 0 1 0 /* Port 3.0 IO */>;
  99. pcie1: pcie@1,0 {
  100. device_type = "pci";
  101. assigned-addresses = <0x82000800 0 0x40000 0 0x2000>;
  102. reg = <0x0800 0 0 0 0>;
  103. #address-cells = <3>;
  104. #size-cells = <2>;
  105. interrupt-names = "intx";
  106. interrupts-extended = <&mpic 58>;
  107. #interrupt-cells = <1>;
  108. ranges = <0x82000000 0 0 0x82000000 0x1 0 1 0
  109. 0x81000000 0 0 0x81000000 0x1 0 1 0>;
  110. bus-range = <0x00 0xff>;
  111. interrupt-map-mask = <0 0 0 7>;
  112. interrupt-map = <0 0 0 1 &pcie1_intc 0>,
  113. <0 0 0 2 &pcie1_intc 1>,
  114. <0 0 0 3 &pcie1_intc 2>,
  115. <0 0 0 4 &pcie1_intc 3>;
  116. marvell,pcie-port = <0>;
  117. marvell,pcie-lane = <0>;
  118. clocks = <&gateclk 5>;
  119. status = "disabled";
  120. pcie1_intc: interrupt-controller {
  121. interrupt-controller;
  122. #interrupt-cells = <1>;
  123. };
  124. };
  125. pcie2: pcie@2,0 {
  126. device_type = "pci";
  127. assigned-addresses = <0x82001000 0 0x44000 0 0x2000>;
  128. reg = <0x1000 0 0 0 0>;
  129. #address-cells = <3>;
  130. #size-cells = <2>;
  131. interrupt-names = "intx";
  132. interrupts-extended = <&mpic 59>;
  133. #interrupt-cells = <1>;
  134. ranges = <0x82000000 0 0 0x82000000 0x2 0 1 0
  135. 0x81000000 0 0 0x81000000 0x2 0 1 0>;
  136. bus-range = <0x00 0xff>;
  137. interrupt-map-mask = <0 0 0 7>;
  138. interrupt-map = <0 0 0 1 &pcie2_intc 0>,
  139. <0 0 0 2 &pcie2_intc 1>,
  140. <0 0 0 3 &pcie2_intc 2>,
  141. <0 0 0 4 &pcie2_intc 3>;
  142. marvell,pcie-port = <0>;
  143. marvell,pcie-lane = <1>;
  144. clocks = <&gateclk 6>;
  145. status = "disabled";
  146. pcie2_intc: interrupt-controller {
  147. interrupt-controller;
  148. #interrupt-cells = <1>;
  149. };
  150. };
  151. pcie3: pcie@3,0 {
  152. device_type = "pci";
  153. assigned-addresses = <0x82001800 0 0x48000 0 0x2000>;
  154. reg = <0x1800 0 0 0 0>;
  155. #address-cells = <3>;
  156. #size-cells = <2>;
  157. interrupt-names = "intx";
  158. interrupts-extended = <&mpic 60>;
  159. #interrupt-cells = <1>;
  160. ranges = <0x82000000 0 0 0x82000000 0x3 0 1 0
  161. 0x81000000 0 0 0x81000000 0x3 0 1 0>;
  162. bus-range = <0x00 0xff>;
  163. interrupt-map-mask = <0 0 0 7>;
  164. interrupt-map = <0 0 0 1 &pcie3_intc 0>,
  165. <0 0 0 2 &pcie3_intc 1>,
  166. <0 0 0 3 &pcie3_intc 2>,
  167. <0 0 0 4 &pcie3_intc 3>;
  168. marvell,pcie-port = <0>;
  169. marvell,pcie-lane = <2>;
  170. clocks = <&gateclk 7>;
  171. status = "disabled";
  172. pcie3_intc: interrupt-controller {
  173. interrupt-controller;
  174. #interrupt-cells = <1>;
  175. };
  176. };
  177. pcie4: pcie@4,0 {
  178. device_type = "pci";
  179. assigned-addresses = <0x82002000 0 0x4c000 0 0x2000>;
  180. reg = <0x2000 0 0 0 0>;
  181. #address-cells = <3>;
  182. #size-cells = <2>;
  183. interrupt-names = "intx";
  184. interrupts-extended = <&mpic 61>;
  185. #interrupt-cells = <1>;
  186. ranges = <0x82000000 0 0 0x82000000 0x4 0 1 0
  187. 0x81000000 0 0 0x81000000 0x4 0 1 0>;
  188. bus-range = <0x00 0xff>;
  189. interrupt-map-mask = <0 0 0 7>;
  190. interrupt-map = <0 0 0 1 &pcie4_intc 0>,
  191. <0 0 0 2 &pcie4_intc 1>,
  192. <0 0 0 3 &pcie4_intc 2>,
  193. <0 0 0 4 &pcie4_intc 3>;
  194. marvell,pcie-port = <0>;
  195. marvell,pcie-lane = <3>;
  196. clocks = <&gateclk 8>;
  197. status = "disabled";
  198. pcie4_intc: interrupt-controller {
  199. interrupt-controller;
  200. #interrupt-cells = <1>;
  201. };
  202. };
  203. pcie5: pcie@5,0 {
  204. device_type = "pci";
  205. assigned-addresses = <0x82002800 0 0x80000 0 0x2000>;
  206. reg = <0x2800 0 0 0 0>;
  207. #address-cells = <3>;
  208. #size-cells = <2>;
  209. interrupt-names = "intx";
  210. interrupts-extended = <&mpic 62>;
  211. #interrupt-cells = <1>;
  212. ranges = <0x82000000 0 0 0x82000000 0x5 0 1 0
  213. 0x81000000 0 0 0x81000000 0x5 0 1 0>;
  214. bus-range = <0x00 0xff>;
  215. interrupt-map-mask = <0 0 0 7>;
  216. interrupt-map = <0 0 0 1 &pcie5_intc 0>,
  217. <0 0 0 2 &pcie5_intc 1>,
  218. <0 0 0 3 &pcie5_intc 2>,
  219. <0 0 0 4 &pcie5_intc 3>;
  220. marvell,pcie-port = <1>;
  221. marvell,pcie-lane = <0>;
  222. clocks = <&gateclk 9>;
  223. status = "disabled";
  224. pcie5_intc: interrupt-controller {
  225. interrupt-controller;
  226. #interrupt-cells = <1>;
  227. };
  228. };
  229. pcie6: pcie@6,0 {
  230. device_type = "pci";
  231. assigned-addresses = <0x82003000 0 0x84000 0 0x2000>;
  232. reg = <0x3000 0 0 0 0>;
  233. #address-cells = <3>;
  234. #size-cells = <2>;
  235. interrupt-names = "intx";
  236. interrupts-extended = <&mpic 63>;
  237. #interrupt-cells = <1>;
  238. ranges = <0x82000000 0 0 0x82000000 0x6 0 1 0
  239. 0x81000000 0 0 0x81000000 0x6 0 1 0>;
  240. bus-range = <0x00 0xff>;
  241. interrupt-map-mask = <0 0 0 7>;
  242. interrupt-map = <0 0 0 1 &pcie6_intc 0>,
  243. <0 0 0 2 &pcie6_intc 1>,
  244. <0 0 0 3 &pcie6_intc 2>,
  245. <0 0 0 4 &pcie6_intc 3>;
  246. marvell,pcie-port = <1>;
  247. marvell,pcie-lane = <1>;
  248. clocks = <&gateclk 10>;
  249. status = "disabled";
  250. pcie6_intc: interrupt-controller {
  251. interrupt-controller;
  252. #interrupt-cells = <1>;
  253. };
  254. };
  255. pcie7: pcie@7,0 {
  256. device_type = "pci";
  257. assigned-addresses = <0x82003800 0 0x88000 0 0x2000>;
  258. reg = <0x3800 0 0 0 0>;
  259. #address-cells = <3>;
  260. #size-cells = <2>;
  261. interrupt-names = "intx";
  262. interrupts-extended = <&mpic 64>;
  263. #interrupt-cells = <1>;
  264. ranges = <0x82000000 0 0 0x82000000 0x7 0 1 0
  265. 0x81000000 0 0 0x81000000 0x7 0 1 0>;
  266. bus-range = <0x00 0xff>;
  267. interrupt-map-mask = <0 0 0 7>;
  268. interrupt-map = <0 0 0 1 &pcie7_intc 0>,
  269. <0 0 0 2 &pcie7_intc 1>,
  270. <0 0 0 3 &pcie7_intc 2>,
  271. <0 0 0 4 &pcie7_intc 3>;
  272. marvell,pcie-port = <1>;
  273. marvell,pcie-lane = <2>;
  274. clocks = <&gateclk 11>;
  275. status = "disabled";
  276. pcie7_intc: interrupt-controller {
  277. interrupt-controller;
  278. #interrupt-cells = <1>;
  279. };
  280. };
  281. pcie8: pcie@8,0 {
  282. device_type = "pci";
  283. assigned-addresses = <0x82004000 0 0x8c000 0 0x2000>;
  284. reg = <0x4000 0 0 0 0>;
  285. #address-cells = <3>;
  286. #size-cells = <2>;
  287. interrupt-names = "intx";
  288. interrupts-extended = <&mpic 65>;
  289. #interrupt-cells = <1>;
  290. ranges = <0x82000000 0 0 0x82000000 0x8 0 1 0
  291. 0x81000000 0 0 0x81000000 0x8 0 1 0>;
  292. bus-range = <0x00 0xff>;
  293. interrupt-map-mask = <0 0 0 7>;
  294. interrupt-map = <0 0 0 1 &pcie8_intc 0>,
  295. <0 0 0 2 &pcie8_intc 1>,
  296. <0 0 0 3 &pcie8_intc 2>,
  297. <0 0 0 4 &pcie8_intc 3>;
  298. marvell,pcie-port = <1>;
  299. marvell,pcie-lane = <3>;
  300. clocks = <&gateclk 12>;
  301. status = "disabled";
  302. pcie8_intc: interrupt-controller {
  303. interrupt-controller;
  304. #interrupt-cells = <1>;
  305. };
  306. };
  307. pcie9: pcie@9,0 {
  308. device_type = "pci";
  309. assigned-addresses = <0x82004800 0 0x42000 0 0x2000>;
  310. reg = <0x4800 0 0 0 0>;
  311. #address-cells = <3>;
  312. #size-cells = <2>;
  313. interrupt-names = "intx";
  314. interrupts-extended = <&mpic 99>;
  315. #interrupt-cells = <1>;
  316. ranges = <0x82000000 0 0 0x82000000 0x9 0 1 0
  317. 0x81000000 0 0 0x81000000 0x9 0 1 0>;
  318. bus-range = <0x00 0xff>;
  319. interrupt-map-mask = <0 0 0 7>;
  320. interrupt-map = <0 0 0 1 &pcie9_intc 0>,
  321. <0 0 0 2 &pcie9_intc 1>,
  322. <0 0 0 3 &pcie9_intc 2>,
  323. <0 0 0 4 &pcie9_intc 3>;
  324. marvell,pcie-port = <2>;
  325. marvell,pcie-lane = <0>;
  326. clocks = <&gateclk 26>;
  327. status = "disabled";
  328. pcie9_intc: interrupt-controller {
  329. interrupt-controller;
  330. #interrupt-cells = <1>;
  331. };
  332. };
  333. pcie10: pcie@a,0 {
  334. device_type = "pci";
  335. assigned-addresses = <0x82005000 0 0x82000 0 0x2000>;
  336. reg = <0x5000 0 0 0 0>;
  337. #address-cells = <3>;
  338. #size-cells = <2>;
  339. interrupt-names = "intx";
  340. interrupts-extended = <&mpic 103>;
  341. #interrupt-cells = <1>;
  342. ranges = <0x82000000 0 0 0x82000000 0xa 0 1 0
  343. 0x81000000 0 0 0x81000000 0xa 0 1 0>;
  344. bus-range = <0x00 0xff>;
  345. interrupt-map-mask = <0 0 0 7>;
  346. interrupt-map = <0 0 0 1 &pcie10_intc 0>,
  347. <0 0 0 2 &pcie10_intc 1>,
  348. <0 0 0 3 &pcie10_intc 2>,
  349. <0 0 0 4 &pcie10_intc 3>;
  350. marvell,pcie-port = <3>;
  351. marvell,pcie-lane = <0>;
  352. clocks = <&gateclk 27>;
  353. status = "disabled";
  354. pcie10_intc: interrupt-controller {
  355. interrupt-controller;
  356. #interrupt-cells = <1>;
  357. };
  358. };
  359. };
  360. internal-regs {
  361. gpio0: gpio@18100 {
  362. compatible = "marvell,armada-370-gpio",
  363. "marvell,orion-gpio";
  364. reg = <0x18100 0x40>, <0x181c0 0x08>;
  365. reg-names = "gpio", "pwm";
  366. ngpios = <32>;
  367. gpio-controller;
  368. #gpio-cells = <2>;
  369. #pwm-cells = <2>;
  370. interrupt-controller;
  371. #interrupt-cells = <2>;
  372. interrupts = <82>, <83>, <84>, <85>;
  373. clocks = <&coreclk 0>;
  374. };
  375. gpio1: gpio@18140 {
  376. compatible = "marvell,armada-370-gpio",
  377. "marvell,orion-gpio";
  378. reg = <0x18140 0x40>, <0x181c8 0x08>;
  379. reg-names = "gpio", "pwm";
  380. ngpios = <32>;
  381. gpio-controller;
  382. #gpio-cells = <2>;
  383. #pwm-cells = <2>;
  384. interrupt-controller;
  385. #interrupt-cells = <2>;
  386. interrupts = <87>, <88>, <89>, <90>;
  387. clocks = <&coreclk 0>;
  388. };
  389. gpio2: gpio@18180 {
  390. compatible = "marvell,armada-370-gpio",
  391. "marvell,orion-gpio";
  392. reg = <0x18180 0x40>;
  393. ngpios = <3>;
  394. gpio-controller;
  395. #gpio-cells = <2>;
  396. interrupt-controller;
  397. #interrupt-cells = <2>;
  398. interrupts = <91>;
  399. };
  400. eth3: ethernet@34000 {
  401. compatible = "marvell,armada-xp-neta";
  402. reg = <0x34000 0x4000>;
  403. interrupts = <14>;
  404. clocks = <&gateclk 1>;
  405. status = "disabled";
  406. };
  407. };
  408. };
  409. };
  410. &pinctrl {
  411. compatible = "marvell,mv78460-pinctrl";
  412. };