mt7621.dtsi 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454
  1. #include <dt-bindings/interrupt-controller/mips-gic.h>
  2. / {
  3. #address-cells = <1>;
  4. #size-cells = <1>;
  5. compatible = "mediatek,mt7621-soc";
  6. cpus {
  7. cpu@0 {
  8. compatible = "mips,mips1004Kc";
  9. };
  10. cpu@1 {
  11. compatible = "mips,mips1004Kc";
  12. };
  13. };
  14. cpuintc: cpuintc@0 {
  15. #address-cells = <0>;
  16. #interrupt-cells = <1>;
  17. interrupt-controller;
  18. compatible = "mti,cpu-interrupt-controller";
  19. };
  20. aliases {
  21. serial0 = &uartlite;
  22. };
  23. cpuclock: cpuclock@0 {
  24. #clock-cells = <0>;
  25. compatible = "fixed-clock";
  26. /* FIXME: there should be way to detect this */
  27. clock-frequency = <880000000>;
  28. };
  29. sysclock: sysclock@0 {
  30. #clock-cells = <0>;
  31. compatible = "fixed-clock";
  32. /* This is normally 1/4 of cpuclock */
  33. clock-frequency = <220000000>;
  34. };
  35. palmbus: palmbus@1E000000 {
  36. compatible = "palmbus";
  37. reg = <0x1E000000 0x100000>;
  38. ranges = <0x0 0x1E000000 0x0FFFFF>;
  39. #address-cells = <1>;
  40. #size-cells = <1>;
  41. sysc: sysc@0 {
  42. compatible = "mtk,mt7621-sysc";
  43. reg = <0x0 0x100>;
  44. };
  45. wdt: wdt@100 {
  46. compatible = "mtk,mt7621-wdt";
  47. reg = <0x100 0x100>;
  48. };
  49. gpio: gpio@600 {
  50. #gpio-cells = <2>;
  51. #interrupt-cells = <2>;
  52. compatible = "mediatek,mt7621-gpio";
  53. gpio-controller;
  54. interrupt-controller;
  55. reg = <0x600 0x100>;
  56. interrupt-parent = <&gic>;
  57. interrupts = <GIC_SHARED 12 IRQ_TYPE_LEVEL_HIGH>;
  58. };
  59. i2c: i2c@900 {
  60. compatible = "mediatek,mt7621-i2c";
  61. reg = <0x900 0x100>;
  62. clocks = <&sysclock>;
  63. resets = <&rstctrl 16>;
  64. reset-names = "i2c";
  65. #address-cells = <1>;
  66. #size-cells = <0>;
  67. status = "disabled";
  68. pinctrl-names = "default";
  69. pinctrl-0 = <&i2c_pins>;
  70. };
  71. i2s: i2s@a00 {
  72. compatible = "mediatek,mt7621-i2s";
  73. reg = <0xa00 0x100>;
  74. clocks = <&sysclock>;
  75. resets = <&rstctrl 17>;
  76. reset-names = "i2s";
  77. interrupt-parent = <&gic>;
  78. interrupts = <GIC_SHARED 16 IRQ_TYPE_LEVEL_HIGH>;
  79. txdma-req = <2>;
  80. rxdma-req = <3>;
  81. dmas = <&gdma 4>,
  82. <&gdma 6>;
  83. dma-names = "tx", "rx";
  84. status = "disabled";
  85. };
  86. memc: memc@5000 {
  87. compatible = "mtk,mt7621-memc";
  88. reg = <0x300 0x100>;
  89. };
  90. cpc: cpc@1fbf0000 {
  91. compatible = "mtk,mt7621-cpc";
  92. reg = <0x1fbf0000 0x8000>;
  93. };
  94. mc: mc@1fbf8000 {
  95. compatible = "mtk,mt7621-mc";
  96. reg = <0x1fbf8000 0x8000>;
  97. };
  98. uartlite: uartlite@c00 {
  99. compatible = "ns16550a";
  100. reg = <0xc00 0x100>;
  101. clocks = <&sysclock>;
  102. clock-frequency = <50000000>;
  103. interrupt-parent = <&gic>;
  104. interrupts = <GIC_SHARED 26 IRQ_TYPE_LEVEL_HIGH>;
  105. reg-shift = <2>;
  106. reg-io-width = <4>;
  107. no-loopback-test;
  108. };
  109. spi0: spi@b00 {
  110. status = "disabled";
  111. compatible = "ralink,mt7621-spi";
  112. reg = <0xb00 0x100>;
  113. clocks = <&sysclock>;
  114. resets = <&rstctrl 18>;
  115. reset-names = "spi";
  116. #address-cells = <1>;
  117. #size-cells = <0>;
  118. pinctrl-names = "default";
  119. pinctrl-0 = <&spi_pins>;
  120. };
  121. gdma: gdma@2800 {
  122. compatible = "ralink,rt3883-gdma";
  123. reg = <0x2800 0x800>;
  124. resets = <&rstctrl 14>;
  125. reset-names = "dma";
  126. interrupt-parent = <&gic>;
  127. interrupts = <0 13 4>;
  128. #dma-cells = <1>;
  129. #dma-channels = <16>;
  130. #dma-requests = <16>;
  131. status = "disabled";
  132. };
  133. hsdma: hsdma@7000 {
  134. compatible = "mediatek,mt7621-hsdma";
  135. reg = <0x7000 0x1000>;
  136. resets = <&rstctrl 5>;
  137. reset-names = "hsdma";
  138. interrupt-parent = <&gic>;
  139. interrupts = <0 11 4>;
  140. #dma-cells = <1>;
  141. #dma-channels = <1>;
  142. #dma-requests = <1>;
  143. status = "disabled";
  144. };
  145. };
  146. pinctrl: pinctrl {
  147. compatible = "ralink,rt2880-pinmux";
  148. pinctrl-names = "default";
  149. pinctrl-0 = <&state_default>;
  150. state_default: pinctrl0 {
  151. };
  152. i2c_pins: i2c {
  153. i2c {
  154. group = "i2c";
  155. function = "i2c";
  156. };
  157. };
  158. spi_pins: spi {
  159. spi {
  160. group = "spi";
  161. function = "spi";
  162. };
  163. };
  164. uart1_pins: uart1 {
  165. uart1 {
  166. group = "uart1";
  167. function = "uart1";
  168. };
  169. };
  170. uart2_pins: uart2 {
  171. uart2 {
  172. group = "uart2";
  173. function = "uart2";
  174. };
  175. };
  176. uart3_pins: uart3 {
  177. uart3 {
  178. group = "uart3";
  179. function = "uart3";
  180. };
  181. };
  182. rgmii1_pins: rgmii1 {
  183. rgmii1 {
  184. group = "rgmii1";
  185. function = "rgmii1";
  186. };
  187. };
  188. rgmii2_pins: rgmii2 {
  189. rgmii2 {
  190. group = "rgmii2";
  191. function = "rgmii2";
  192. };
  193. };
  194. mdio_pins: mdio {
  195. mdio {
  196. group = "mdio";
  197. function = "mdio";
  198. };
  199. };
  200. pcie_pins: pcie {
  201. pcie {
  202. group = "pcie";
  203. function = "pcie rst";
  204. };
  205. };
  206. nand_pins: nand {
  207. spi-nand {
  208. group = "spi";
  209. function = "nand1";
  210. };
  211. sdhci-nand {
  212. group = "sdhci";
  213. function = "nand2";
  214. };
  215. };
  216. sdhci_pins: sdhci {
  217. sdhci {
  218. group = "sdhci";
  219. function = "sdhci";
  220. };
  221. };
  222. };
  223. rstctrl: rstctrl {
  224. compatible = "ralink,rt2880-reset";
  225. #reset-cells = <1>;
  226. };
  227. clkctrl: clkctrl {
  228. compatible = "ralink,rt2880-clock";
  229. #clock-cells = <1>;
  230. };
  231. sdhci: sdhci@1E130000 {
  232. status = "disabled";
  233. compatible = "ralink,mt7620-sdhci";
  234. reg = <0x1E130000 0x4000>;
  235. interrupt-parent = <&gic>;
  236. interrupts = <GIC_SHARED 20 IRQ_TYPE_LEVEL_HIGH>;
  237. };
  238. xhci: xhci@1E1C0000 {
  239. status = "okay";
  240. compatible = "mediatek,mt8173-xhci";
  241. reg = <0x1e1c0000 0x1000
  242. 0x1e1d0700 0x0100>;
  243. reg-names = "mac", "ippc";
  244. clocks = <&sysclock>;
  245. clock-names = "sys_ck";
  246. interrupt-parent = <&gic>;
  247. interrupts = <GIC_SHARED 22 IRQ_TYPE_LEVEL_HIGH>;
  248. };
  249. gic: interrupt-controller@1fbc0000 {
  250. compatible = "mti,gic";
  251. reg = <0x1fbc0000 0x2000>;
  252. interrupt-controller;
  253. #interrupt-cells = <3>;
  254. mti,reserved-cpu-vectors = <7>;
  255. timer {
  256. compatible = "mti,gic-timer";
  257. interrupts = <GIC_LOCAL 1 IRQ_TYPE_NONE>;
  258. clocks = <&cpuclock>;
  259. };
  260. };
  261. nand: nand@1e003000 {
  262. status = "disabled";
  263. compatible = "mtk,mt7621-nand";
  264. bank-width = <2>;
  265. reg = <0x1e003000 0x800
  266. 0x1e003800 0x800>;
  267. #address-cells = <1>;
  268. #size-cells = <1>;
  269. };
  270. ethsys: syscon@1e000000 {
  271. compatible = "mediatek,mt7621-ethsys",
  272. "syscon";
  273. reg = <0x1e000000 0x1000>;
  274. #clock-cells = <1>;
  275. };
  276. ethernet: ethernet@1e100000 {
  277. compatible = "mediatek,mt7621-eth";
  278. reg = <0x1e100000 0x10000>;
  279. clocks = <&sysclock>;
  280. clock-names = "ethif";
  281. #address-cells = <1>;
  282. #size-cells = <0>;
  283. resets = <&rstctrl 6 &rstctrl 23>;
  284. reset-names = "fe", "eth";
  285. interrupt-parent = <&gic>;
  286. interrupts = <GIC_SHARED 3 IRQ_TYPE_LEVEL_HIGH>;
  287. mediatek,ethsys = <&ethsys>;
  288. mediatek,switch = <&gsw>;
  289. mdio-bus {
  290. #address-cells = <1>;
  291. #size-cells = <0>;
  292. phy1f: ethernet-phy@1f {
  293. reg = <0x1f>;
  294. phy-mode = "rgmii";
  295. };
  296. };
  297. };
  298. gsw: gsw@1e110000 {
  299. compatible = "mediatek,mt7621-gsw";
  300. reg = <0x1e110000 0x8000>;
  301. interrupt-parent = <&gic>;
  302. interrupts = <GIC_SHARED 23 IRQ_TYPE_LEVEL_HIGH>;
  303. };
  304. pcie: pcie@1e140000 {
  305. compatible = "mediatek,mt7621-pci";
  306. reg = <0x1e140000 0x100 /* host-pci bridge registers */
  307. 0x1e142000 0x100 /* pcie port 0 RC control registers */
  308. 0x1e143000 0x100 /* pcie port 1 RC control registers */
  309. 0x1e144000 0x100>; /* pcie port 2 RC control registers */
  310. #address-cells = <3>;
  311. #size-cells = <2>;
  312. pinctrl-names = "default";
  313. pinctrl-0 = <&pcie_pins>;
  314. device_type = "pci";
  315. bus-range = <0 255>;
  316. ranges = <
  317. 0x02000000 0 0x00000000 0x60000000 0 0x10000000 /* pci memory */
  318. 0x01000000 0 0x00000000 0x1e160000 0 0x00010000 /* io space */
  319. >;
  320. #interrupt-cells = <1>;
  321. interrupt-map-mask = <0xF0000 0 0 1>;
  322. interrupt-map = <0x10000 0 0 1 &gic GIC_SHARED 4 IRQ_TYPE_LEVEL_HIGH>,
  323. <0x20000 0 0 1 &gic GIC_SHARED 24 IRQ_TYPE_LEVEL_HIGH>,
  324. <0x30000 0 0 1 &gic GIC_SHARED 25 IRQ_TYPE_LEVEL_HIGH>;
  325. status = "disabled";
  326. resets = <&rstctrl 24 &rstctrl 25 &rstctrl 26>;
  327. reset-names = "pcie0", "pcie1", "pcie2";
  328. clocks = <&clkctrl 24 &clkctrl 25 &clkctrl 26>;
  329. clock-names = "pcie0", "pcie1", "pcie2";
  330. pcie@0,0 {
  331. reg = <0x0000 0 0 0 0>;
  332. #address-cells = <3>;
  333. #size-cells = <2>;
  334. ranges;
  335. bus-range = <0x00 0xff>;
  336. };
  337. pcie@1,0 {
  338. reg = <0x0800 0 0 0 0>;
  339. #address-cells = <3>;
  340. #size-cells = <2>;
  341. ranges;
  342. bus-range = <0x00 0xff>;
  343. };
  344. pcie@2,0 {
  345. reg = <0x1000 0 0 0 0>;
  346. #address-cells = <3>;
  347. #size-cells = <2>;
  348. ranges;
  349. bus-range = <0x00 0xff>;
  350. };
  351. };
  352. };