mt7986b-mercusys-mr90x-v1.dts 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. // SPDX-License-Identifier: (GL-2.0 OR MIT)
  2. /dts-v1/;
  3. #include <dt-bindings/input/input.h>
  4. #include <dt-bindings/gpio/gpio.h>
  5. #include "mt7986b.dtsi"
  6. / {
  7. compatible = "mercusys,mr90x-v1", "mediatek,mt7986b";
  8. model = "MERCUSYS MR90X v1";
  9. aliases {
  10. serial0 = &uart0;
  11. led-boot = &led_status_green;
  12. led-failsafe = &led_status_green;
  13. led-running = &led_status_green;
  14. led-upgrade = &led_status_green;
  15. };
  16. chosen {
  17. stdout-path = "serial0:115200n8";
  18. };
  19. memory {
  20. reg = <0 0x40000000 0 0x20000000>;
  21. };
  22. keys {
  23. compatible = "gpio-keys";
  24. reset {
  25. label = "reset";
  26. gpios = <&pio 10 GPIO_ACTIVE_LOW>;
  27. linux,code = <KEY_RESTART>;
  28. };
  29. };
  30. leds {
  31. compatible = "gpio-leds";
  32. led-0 {
  33. label = "green:lan2";
  34. gpios = <&pio 7 GPIO_ACTIVE_LOW>;
  35. };
  36. led-1 {
  37. label = "green:lan1";
  38. gpios = <&pio 9 GPIO_ACTIVE_LOW>;
  39. };
  40. led-2 {
  41. label = "green:lan0";
  42. gpios = <&pio 12 GPIO_ACTIVE_LOW>;
  43. };
  44. led-3 {
  45. label = "green:wan";
  46. gpios = <&pio 13 GPIO_ACTIVE_LOW>;
  47. };
  48. led-4 {
  49. label = "orange:status";
  50. gpios = <&pio 16 GPIO_ACTIVE_HIGH>;
  51. };
  52. led_status_green: led-5 {
  53. label = "green:status";
  54. gpios = <&pio 17 GPIO_ACTIVE_HIGH>;
  55. panic-indicator;
  56. };
  57. };
  58. };
  59. &crypto {
  60. status = "okay";
  61. };
  62. &eth {
  63. status = "okay";
  64. gmac0: mac@0 {
  65. compatible = "mediatek,eth-mac";
  66. reg = <0>;
  67. phy-mode = "2500base-x";
  68. fixed-link {
  69. speed = <2500>;
  70. full-duplex;
  71. pause;
  72. };
  73. };
  74. gmac1: mac@1 {
  75. compatible = "mediatek,eth-mac";
  76. reg = <1>;
  77. phy-handle = <&phy6>;
  78. phy-mode = "2500base-x";
  79. };
  80. mdio: mdio-bus {
  81. #address-cells = <1>;
  82. #size-cells = <0>;
  83. };
  84. };
  85. &mdio {
  86. #address-cells = <1>;
  87. #size-cells = <0>;
  88. reset-gpios = <&pio 6 GPIO_ACTIVE_LOW>;
  89. reset-delay-us = <1500000>;
  90. reset-post-delay-us = <1000000>;
  91. /* WAN/LAN 2.5Gbps phy
  92. MaxLinear GPY211C0VC (SLNW8) */
  93. phy6: phy@6 {
  94. compatible = "ethernet-phy-ieee802.3-c45";
  95. reg = <6>;
  96. };
  97. switch: switch@0 {
  98. compatible = "mediatek,mt7531";
  99. reg = <31>;
  100. reset-gpios = <&pio 5 GPIO_ACTIVE_HIGH>;
  101. };
  102. };
  103. &switch {
  104. ports {
  105. #address-cells = <1>;
  106. #size-cells = <0>;
  107. /* WAN/LAN 1Gbps port */
  108. port@0 {
  109. reg = <0>;
  110. label = "lan0";
  111. };
  112. /* LAN1 port */
  113. port@1 {
  114. reg = <1>;
  115. label = "lan1";
  116. };
  117. /* LAN2 port */
  118. port@2 {
  119. reg = <2>;
  120. label = "lan2";
  121. };
  122. port@6 {
  123. reg = <6>;
  124. ethernet = <&gmac0>;
  125. phy-mode = "2500base-x";
  126. fixed-link {
  127. speed = <2500>;
  128. full-duplex;
  129. pause;
  130. };
  131. };
  132. };
  133. };
  134. &pio {
  135. spi_flash_pins: spi-flash-pins-33-to-38 {
  136. mux {
  137. function = "spi";
  138. groups = "spi0", "spi0_wp_hold";
  139. };
  140. conf-pu {
  141. pins = "SPI2_CS", "SPI2_HOLD", "SPI2_WP";
  142. drive-strength = <8>;
  143. mediatek,pull-up-adv = <0>; /* bias-disable */
  144. };
  145. conf-pd {
  146. pins = "SPI2_CLK", "SPI2_MOSI", "SPI2_MISO";
  147. drive-strength = <8>;
  148. mediatek,pull-down-adv = <0>; /* bias-disable */
  149. };
  150. };
  151. wf_2g_5g_pins: wf_2g_5g-pins {
  152. mux {
  153. function = "wifi";
  154. groups = "wf_2g", "wf_5g";
  155. };
  156. conf {
  157. pins = "WF0_HB1", "WF0_HB2", "WF0_HB3", "WF0_HB4",
  158. "WF0_HB0", "WF0_HB0_B", "WF0_HB5", "WF0_HB6",
  159. "WF0_HB7", "WF0_HB8", "WF0_HB9", "WF0_HB10",
  160. "WF0_TOP_CLK", "WF0_TOP_DATA", "WF1_HB1",
  161. "WF1_HB2", "WF1_HB3", "WF1_HB4", "WF1_HB0",
  162. "WF1_HB5", "WF1_HB6", "WF1_HB7", "WF1_HB8",
  163. "WF1_TOP_CLK", "WF1_TOP_DATA";
  164. drive-strength = <4>;
  165. };
  166. };
  167. };
  168. &spi0 {
  169. pinctrl-names = "default";
  170. pinctrl-0 = <&spi_flash_pins>;
  171. status = "okay";
  172. spi_nand_flash: flash@0 {
  173. compatible = "spi-nand";
  174. #address-cells = <1>;
  175. #size-cells = <1>;
  176. reg = <0>;
  177. spi-max-frequency = <20000000>;
  178. spi-tx-bus-width = <4>;
  179. spi-rx-bus-width = <4>;
  180. partitions: partitions {
  181. compatible = "fixed-partitions";
  182. #address-cells = <1>;
  183. #size-cells = <1>;
  184. partition@0 {
  185. label = "boot";
  186. reg = <0x0 0x200000>;
  187. read-only;
  188. };
  189. partition@200000 {
  190. label = "u-boot-env";
  191. reg = <0x200000 0x100000>;
  192. };
  193. partition@300000 {
  194. label = "ubi0";
  195. reg = <0x300000 0x3200000>;
  196. };
  197. partition@3500000 {
  198. label = "ubi1";
  199. reg = <0x3500000 0x3200000>;
  200. read-only;
  201. };
  202. partition@6700000 {
  203. label = "userconfig";
  204. reg = <0x6700000 0x800000>;
  205. read-only;
  206. };
  207. partition@6f00000 {
  208. label = "tp_data";
  209. reg = <0x6f00000 0x400000>;
  210. read-only;
  211. };
  212. };
  213. };
  214. };
  215. &trng {
  216. status = "okay";
  217. };
  218. &uart0 {
  219. status = "okay";
  220. };
  221. &watchdog {
  222. status = "okay";
  223. };
  224. &wifi {
  225. status = "okay";
  226. pinctrl-names = "default";
  227. pinctrl-0 = <&wf_2g_5g_pins>;
  228. };