rtl931x.dtsi 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  1. // SPDX-License-Identifier: GPL-2.0-or-later OR MIT
  2. #include "macros.dtsi"
  3. #include <dt-bindings/interrupt-controller/mips-gic.h>
  4. /dts-v1/;
  5. / {
  6. #address-cells = <1>;
  7. #size-cells = <1>;
  8. compatible = "realtek,rtl838x-soc";
  9. cpus {
  10. #address-cells = <1>;
  11. #size-cells = <0>;
  12. frequency = <1000000000>;
  13. cpu@0 {
  14. compatible = "mti,interaptive";
  15. reg = <0>;
  16. };
  17. cpu@1 {
  18. compatible = "mti,interaptive";
  19. reg = <1>;
  20. };
  21. };
  22. memory@0 {
  23. device_type = "memory";
  24. reg = <0x0 0x10000000>;
  25. };
  26. aliases {
  27. serial0 = &uart0;
  28. serial1 = &uart1;
  29. };
  30. chosen {
  31. bootargs = "earlycon";
  32. stdout-path = "serial0:115200n8";
  33. };
  34. lx_clk: lx_clk {
  35. compatible = "fixed-clock";
  36. #clock-cells = <0>;
  37. clock-frequency = <200000000>;
  38. };
  39. cpc: cpc@1bde0000 {
  40. compatible = "mti,mips-cpc";
  41. reg = <0x1bde0000 0x8000>;
  42. };
  43. cpuclock: cpuclock@0 {
  44. #clock-cells = <0>;
  45. compatible = "fixed-clock";
  46. /* FIXME: there should be way to detect this */
  47. clock-frequency = <1000000000>;
  48. };
  49. cpuintc: cpuintc {
  50. compatible = "mti,cpu-interrupt-controller";
  51. #address-cells = <0>;
  52. #interrupt-cells = <1>;
  53. interrupt-controller;
  54. };
  55. gic: interrupt-controller@1ddc0000 {
  56. compatible = "mti,gic";
  57. reg = <0x1ddc0000 0x20000>;
  58. interrupt-controller;
  59. #interrupt-cells = <3>;
  60. /*
  61. * Declare the interrupt-parent even though the mti,gic
  62. * binding doesn't require it, such that the kernel can
  63. * figure out that cpu_intc is the root interrupt
  64. * controller & should be probed first.
  65. */
  66. interrupt-parent = <&cpuintc>;
  67. };
  68. soc: soc {
  69. compatible = "simple-bus";
  70. #address-cells = <1>;
  71. #size-cells = <1>;
  72. ranges = <0x0 0x18000000 0x20000>;
  73. spi0: spi@1200 {
  74. status = "okay";
  75. compatible = "realtek,rtl8380-spi";
  76. reg = <0x1200 0x100>;
  77. #address-cells = <1>;
  78. #size-cells = <0>;
  79. };
  80. snand: spi@1a400 {
  81. compatible = "realtek,rtl9301-snand";
  82. reg = <0x1a400 0x44>;
  83. interrupt-parent = <&gic>;
  84. interrupts = <GIC_SHARED 37 IRQ_TYPE_LEVEL_HIGH>;
  85. clocks = <&lx_clk>;
  86. #address-cells = <1>;
  87. #size-cells = <0>;
  88. status = "disabled";
  89. };
  90. watchdog0: watchdog@3260 {
  91. compatible = "realtek,rtl9310-wdt";
  92. reg = <0x3260 0xc>;
  93. realtek,reset-mode = "soc";
  94. clocks = <&lx_clk>;
  95. timeout-sec = <30>;
  96. interrupt-parent = <&gic>;
  97. interrupt-names = "phase1", "phase2";
  98. interrupts = <GIC_SHARED 8 IRQ_TYPE_LEVEL_HIGH>, <GIC_SHARED 9 IRQ_TYPE_LEVEL_HIGH>;
  99. };
  100. gpio0: gpio-controller@3300 {
  101. compatible = "realtek,rtl9310-gpio", "realtek,otto-gpio";
  102. reg = <0x3300 0x1c>;
  103. gpio-controller;
  104. #gpio-cells = <2>;
  105. ngpios = <32>;
  106. interrupt-controller;
  107. #interrupt-cells = <3>;
  108. interrupt-parent = <&gic>;
  109. interrupts = <GIC_SHARED 20 IRQ_TYPE_LEVEL_HIGH>;
  110. };
  111. timer0: timer@3200 {
  112. compatible = "realtek,rtl931x-timer", "realtek,otto-timer";
  113. reg = <0x3200 0x10>, <0x3210 0x10>, <0x3220 0x10>,
  114. <0x3230 0x10>, <0x3240 0x10>, <0x3250 0x10>;
  115. interrupt-parent = <&gic>;
  116. interrupts = <GIC_SHARED 0 IRQ_TYPE_LEVEL_HIGH>, <GIC_SHARED 1 IRQ_TYPE_LEVEL_HIGH>,
  117. <GIC_SHARED 2 IRQ_TYPE_LEVEL_HIGH>, <GIC_SHARED 3 IRQ_TYPE_LEVEL_HIGH>,
  118. <GIC_SHARED 4 IRQ_TYPE_LEVEL_HIGH>, <GIC_SHARED 5 IRQ_TYPE_LEVEL_HIGH>;
  119. clocks = <&lx_clk>;
  120. };
  121. uart0: uart@2000 {
  122. compatible = "ns16550a";
  123. reg = <0x2000 0x100>;
  124. clock-frequency = <200000000>;
  125. interrupt-parent = <&gic>;
  126. #interrupt-cells = <3>;
  127. interrupts = <GIC_SHARED 22 IRQ_TYPE_LEVEL_HIGH>;
  128. reg-io-width = <1>;
  129. reg-shift = <2>;
  130. fifo-size = <1>;
  131. no-loopback-test;
  132. };
  133. uart1: uart@2100 {
  134. compatible = "ns16550a";
  135. reg = <0x2100 0x100>;
  136. clock-frequency = <200000000>;
  137. interrupt-parent = <&gic>;
  138. #interrupt-cells = <3>;
  139. interrupts = <GIC_SHARED 23 IRQ_TYPE_LEVEL_HIGH>;
  140. reg-io-width = <1>;
  141. reg-shift = <2>;
  142. fifo-size = <1>;
  143. no-loopback-test;
  144. status = "disabled";
  145. };
  146. };
  147. switchcore@1b000000 {
  148. compatible = "syscon", "simple-mfd";
  149. reg = <0x1b000000 0x10000>;
  150. i2c_mst1: i2c@100c {
  151. compatible = "realtek,rtl9310-i2c";
  152. reg = <0x100c 0x18>;
  153. #address-cells = <1>;
  154. #size-cells = <0>;
  155. realtek,scl = <0>;
  156. status = "disabled";
  157. };
  158. i2c_mst2: i2c@1024 {
  159. compatible = "realtek,rtl9310-i2c";
  160. reg = <0x1024 0x18>;
  161. #address-cells = <1>;
  162. #size-cells = <0>;
  163. realtek,scl = <1>;
  164. status = "disabled";
  165. };
  166. mdio_aux: mdio-aux {
  167. compatible = "realtek,rtl9310-aux-mdio";
  168. #address-cells = <1>;
  169. #size-cells = <0>;
  170. pinctrl-0 = <&pinmux_gpio_mdio_en>;
  171. pinctrl-names = "default";
  172. status = "disabled";
  173. };
  174. };
  175. pinmux@1b0007d4 {
  176. compatible = "pinctrl-single";
  177. reg = <0x1b0007d4 0x4>;
  178. pinctrl-single,bit-per-mux;
  179. pinctrl-single,register-width = <32>;
  180. pinctrl-single,function-mask = <0x1>;
  181. #pinctrl-cells = <2>;
  182. pinmux_gpio_mdio_en: gpio-mdio-en {
  183. pinctrl-single,bits = <0x0 0x100 0x100>;
  184. };
  185. };
  186. ethernet0: ethernet@1b00a300 {
  187. status = "okay";
  188. compatible = "realtek,rtl838x-eth";
  189. reg = <0x1b00a300 0x100>;
  190. interrupt-parent = <&gic>;
  191. #interrupt-cells = <3>;
  192. interrupts = <GIC_SHARED 16 IRQ_TYPE_LEVEL_HIGH>;
  193. phy-mode = "internal";
  194. fixed-link {
  195. speed = <1000>;
  196. full-duplex;
  197. };
  198. };
  199. switch0: switch@1b000000 {
  200. compatible = "realtek,rtl83xx-switch";
  201. status = "okay";
  202. interrupt-parent = <&gic>;
  203. #interrupt-cells = <3>;
  204. interrupts = <GIC_SHARED 15 IRQ_TYPE_LEVEL_HIGH>;
  205. };
  206. };